

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

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

(11) 特許番号

特許第6779687号  
(P6779687)

(45) 発行日 令和2年11月4日(2020.11.4)

(24) 登録日 令和2年10月16日(2020.10.16)

|               |               |
|---------------|---------------|
| (51) Int.Cl.  | F 1           |
| B 4 1 J 29/38 | (2006.01)     |
| HO 4 N 1/00   | (2006.01)     |
| GO 6 F 1/32   | (2019.01)     |
|               |               |
|               | B 4 1 J 29/38 |
|               | HO 4 N 1/00   |
|               | HO 4 N 1/00   |
|               | GO 6 F 1/32   |
|               |               |

請求項の数 14 (全 22 頁)

(21) 出願番号 特願2016-145604 (P2016-145604)  
 (22) 出願日 平成28年7月25日 (2016.7.25)  
 (65) 公開番号 特開2018-15914 (P2018-15914A)  
 (43) 公開日 平成30年2月1日 (2018.2.1)  
 審査請求日 令和1年7月23日 (2019.7.23)

(73) 特許権者 000001007  
 キヤノン株式会社  
 東京都大田区下丸子3丁目30番2号  
 (74) 代理人 100090273  
 弁理士 國分 孝悦  
 (72) 発明者 松本 昭浩  
 東京都大田区下丸子3丁目30番2号 キ  
 ャノン株式会社内

審査官 上田 正樹

最終頁に続く

(54) 【発明の名称】電子機器及び電子機器の制御方法

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

## 【請求項 1】

通常の電力状態から複数の省電力状態に遷移可能な電子機器であって、ストレージデバイスと、少なくとも1つのプロセッサと少なくとも1つのメモリを含む第1コントローラと、所定の通信規格に従う所定の物理通信インターフェースを介して前記第1コントローラ及び前記ストレージデバイスと通信する第2コントローラとを有し、前記電子機器が前記複数の省電力状態のうちのいずれかの省電力状態に移行することに従って、前記第1コントローラは、前記移行する省電力状態に応じた省電力モードに前記第2コントローラを移行させ、省電力モードに移行した前記第2コントローラは、前記ストレージデバイスの電源をオフにし、且つ、

前記電子機器が前記複数の省電力状態のうちのいずれかの省電力状態から復帰することに従って、前記第1コントローラは、前記第2コントローラを前記省電力モードから復帰させ、復帰した前記第2コントローラは、第1コマンドを受け付けたことに基づいて前記ストレージデバイスの電源をオンさせ、前記第1コマンドと異なる第2コマンドを受け付けたことに基づいて前記ストレージデバイスの電源をオンさせないことを特徴とする電子機器。

## 【請求項 2】

前記所定の通信規格はS A T A 規格であり、

10

20

前記第2コントローラは、前記第1コントローラに接続される第1のSATA制御部と、第1のインターフェースを介して前記第1のSATA制御部に接続される第2のSATA制御部とを含み、

前記ストレージデバイスは、第2のインターフェースを介して前記第2のSATA制御部に接続され、

前記電子機器がアイドル状態から前記複数の省電力状態のうちのいずれかの省電力状態に移行することに従って、前記第1コントローラは、前記移行する省電力状態に応じた省電力モードに前記第1のSATA制御部を移行させ、

前記第1のSATA制御部は、前記第2のSATA制御部を前記省電力モードに移行させ、

前記第2のSATA制御部は、前記省電力モードに移行すると前記ストレージデバイスの電源をオフにする第1の電源オフモード又は第2の電源オフモードに移行させることを特徴とする請求項1記載の電子機器。

#### 【請求項3】

前記第1のSATA制御部は、前記第1コントローラによりアイドル状態から省電力状態への移行が指示されると、前記第1のインターフェースに対して省電力状態への移行処理を行い、自身に対して省電力状態への移行処理を行い、

前記第2のSATA制御部は、前記第1のSATA制御部によりアイドル状態から省電力状態への移行が指示されると、前記第2のインターフェースに対して省電力状態への移行処理を行い、自身に対して省電力状態への移行処理を行うことを特徴とする請求項2記載の電子機器。

#### 【請求項4】

前記第2のSATA制御部は、省電力状態からアイドル状態への復帰した後、前記第1のSATA制御部からATAコマンドを受信すると、前記第1の電源オフモードであることに基づいて、前記ストレージデバイスの電源をオンさせるために前記ATAコマンドの処理を行うことを特徴とする請求項2記載の電子機器。

#### 【請求項5】

前記第2のSATA制御部は、省電力状態からアイドル状態への復帰した後、前記第1のSATA制御部からATAコマンドを受信すると、前記第1の電源オフモードであることに基づいて、前記ストレージデバイスに対してアイドル状態への復帰処理を行い、前記第2のインターフェースに対してアイドル状態への復帰処理を行うことを特徴とする請求項4記載の電子機器。

#### 【請求項6】

前記第1コントローラは、前記第1のSATA制御部に対して前記第1のインターフェースの省電力移行の設定を行い、前記第2のSATA制御部に対して前記第2のインターフェース及び前記ストレージデバイスの省電力移行の設定を行い、

前記第1のSATA制御部は、前記第1のインターフェースの省電力移行の設定を基に、前記第1のインターフェースに対して前記移行処理を行い、

前記第2のSATA制御部は、前記第2のインターフェースの省電力移行の設定を基に、前記第2のインターフェースに対して前記移行処理を行い、

前記第2のSATA制御部は、前記ストレージデバイスの省電力移行の設定を基に、前記ストレージデバイスに対して前記移行処理を行うことを特徴とする請求項3記載の電子機器。

#### 【請求項7】

前記第1コントローラは、前記第1のSATA制御部に対して、省電力効果が異なる複数の省電力状態のうちの1つの省電力状態への移行を指示することを特徴とする請求項6記載の電子機器。

#### 【請求項8】

前記第1コントローラは、前記複数の省電力状態毎に、前記第1のSATA制御部に対して前記第1のインターフェースの省電力移行の設定を行い、前記第2のSATA制御部

10

20

30

40

50

に対して前記第2のインターフェース及び前記ストレージデバイスの省電力移行の設定を行うことを特徴とする請求項7記載の電子機器。

【請求項9】

さらに、印刷を行うプリンタを有することを特徴とする請求項1～8のいずれか1項に記載の電子機器。

【請求項10】

前記省電力モードに移行した前記第2コントローラは、前記第2コントローラが前記省電力モードから復帰する際に前記ストレージデバイスを復帰させる第1モードと、前記第2コントローラが前記省電力モードから復帰する際に前記ストレージデバイスを復帰させない第2モードのいずれかに移行することを特徴とする請求項1記載の電子機器。 10

【請求項11】

前記複数の省電力状態は、少なくとも3つの省電力状態を含み、

前記電子機器が第1省電力状態に移行することに従って、前記第1コントローラは、前記第2コントローラを第1省電力モードに移行させ、

前記電子機器が前記第1省電力状態よりも消費電力が低い第2省電力状態に移行することに従って、前記第1コントローラは、前記第2コントローラを前記第1省電力モードよりも消費電力が低い第2省電力モードに移行させ、

前記電子機器が前記第2省電力状態よりも消費電力が低い第3省電力状態に移行することに従って、前記第1コントローラは、前記第2コントローラを前記第2省電力モードよりも消費電力が低い第3省電力モードに移行させることを特徴とする請求項1記載の電子機器。 20

【請求項12】

前記電子機器が前記複数の省電力状態のうちのいずれかの省電力状態から復帰することに従って、前記第1コントローラは、前記第1のSATA制御部を前記省電力モードから復帰させ、

復帰した前記第1のSATA制御部は、前記第2のSATA制御部を前記省電力モードから復帰させ、

前記第2のSATA制御部は、前記省電力モードから復帰する際に、前記ストレージデバイスが前記第1の電源オフモードである場合には前記ストレージデバイスの電源をオンさせず、前記ストレージデバイスが前記第2の電源オフモードである場合には前記ストレージデバイスの電源をオンさせることを特徴とする請求項2記載の電子機器。 30

【請求項13】

前記第1のSATA制御部は、前記第1コントローラにより省電力状態からアイドル状態への復帰が指示されると、前記第1のSATA制御部に対してアイドル状態への復帰処理を行い、前記第1のインターフェースに対してアイドル状態への復帰処理を行い、

前記第2のSATA制御部は、前記第1のSATA制御部により省電力状態からアイドル状態への復帰が指示されると、前記第2のSATA制御部に対してアイドル状態への復帰処理を行い、前記第1のインターフェースに対してアイドル状態への復帰処理を行い、前記第2の電源オフモードである場合には、前記ストレージデバイスに対してアイドル状態への復帰処理を行い、前記第2のインターフェースに対してアイドル状態への復帰処理を行うことを特徴とする請求項3記載の電子機器。 40

【請求項14】

通常の電力状態から複数の省電力状態に遷移可能な電子機器であって、

ストレージデバイスと、

少なくとも1つのプロセッサと少なくとも1つのメモリを含む第1コントローラと、

所定の通信規格に従う所定の物理通信インターフェースを介して前記第1コントローラ及び前記ストレージデバイスと通信する第2コントローラとを有する電子機器の制御方法であって、

前記電子機器が前記複数の省電力状態のうちのいずれかの省電力状態に移行することに従って、前記第1コントローラは、前記移行する省電力状態に応じた省電力モードに前記 50

第2コントローラを移行させ、省電力モードに移行した前記第2コントローラは、前記ストレージデバイスの電源をオフにし、

且つ、

前記電子機器が前記複数の省電力状態のうちのいずれかの省電力状態から復帰することに従って、前記第1コントローラは、前記第2コントローラを前記省電力モードから復帰させ、復帰した前記第2コントローラは、第1コマンドを受け付けたことに基づいて前記ストレージデバイスの電源をオンさせ、前記第1コマンドと異なる第2コマンドを受け付けたことに基づいて前記ストレージデバイスの電源をオンさせないことを特徴とする電子機器の制御方法。

【発明の詳細な説明】

10

【技術分野】

【0001】

本発明は、電子機器及び電子機器の制御方法に関する。

【背景技術】

【0002】

近年、地球温暖化等の環境問題対応として各國の規制は年々厳しくなってきている。印刷装置においても例外ではなく、真摯に環境問題に取り組み、各種エネルギー関連規格への積極的な対応が求められている。また、ノートPC（パーソナルコンピュータ）やタブレットPCなどのモバイル系電子機器の普及に伴い、バッテリによる駆動をより長時間にする必要がある。そのため、内部バスIF（インターフェース）規格であるPCIe（PCI Express）やストレージデバイスとのIF規格であるSATA（Serial ATA）では、規格レベルにおいて省電力状態が策定されている。例えば、SATAでは、従来からの省電力系コマンドに加えて、ホストとデバイス間IFでの省電力状態が追加された。前者としてはStandbyコマンドやSleepコマンドなどが、後者としてはPartial、Sumbler及びDevice-Sleep（以下、DevSleepと示す）が省電力状態として定義されている。ストレージデバイスの代表例として、ハードディスク装置（以下、HDDと示す）やSSD（ソリッドステートドライブ）などが挙げられる。DevSleepは、特にSSDに対して設けられた省電力状態であり、SATA-IF電力と本体電力の両方をRun Timeに削減することを可能とする。

20

【0003】

SATA-IF及びそれに接続されるストレージデバイスは、アクセス期間以外のアイドル状態において比較的に待機電力が大きな部分である。特に、SATAブリッジ構成としてRAID（Redundant Arrays of Inexpensive Disks）制御やデータ暗号化処理を実施する場合である。その場合、ホスト側であるSATAメイン制御部及びデバイス側であるSATAブリッジ制御部のCPUシステムと複数のストレージデバイス及びそれらを接続する複数のSATA-IF（特に物理層）での待機電力は大きなものとなる。そのため、Run Timeな省電力制御が求められる。例えば、PATA（Parallel ATA）-IFを有するHDDとSATA-IFを持つSATAホスト制御部をブリッジする目的のSATAブリッジ構成において、上位メインCPUの手を煩わせることの方法が提案されている。特許文献1では、HDDへの省電力制御状況（SATAブリッジ制御部への省電力系コマンド）に応じて、SATAホスト制御部とデバイス側であるSATAブリッジ制御部間のSATA-IFをPartialやSleepの省電力状態に移行させる。

30

【先行技術文献】

【特許文献】

【0004】

【特許文献1】特開2005-78514号公報

【発明の概要】

【発明が解決しようとする課題】

40

50

## 【0005】

特許文献1は、HDDへの省電力系コマンドを基点としたSATA系省電力移行処理を行う。すなわち、省電力移行条件は、装置全体の電力ステートとは連動せず、あくまでもSATA系部分のみでの省電力移行判定となるため、きめ細かな省電力制御には限界がある。例えば、HDDは、不要時に電源オフし、真に必要な場合にのみ電源オンすることが電力的及び寿命的に望ましい。また、RAID制御に伴うバックグラウンド処理中の省電力移行要求に対して、現状のバックグラウンド処理を継続するのか、中断するのかの適切な判断を必要とする場合がある。しかしながら、特許文献1では、HDD電源オフ/オンタイミングやバックグラウンド処理の継続の有無を適切に判断することは困難である。

## 【0006】

10

本発明の目的は、ストレージデバイス（例えばHDD）のオフ/オン回数に対する寿命を考慮しつつ効率的に消費電力を削減することができる電子機器及び電子機器の制御方法を提供することである。

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

## 【0007】

本発明の電子機器は、通常の電力状態から複数の省電力状態に遷移可能な電子機器であって、ストレージデバイスと、少なくとも1つのプロセッサと少なくとも1つのメモリを含む第1コントローラと、所定の通信規格に従う所定の物理通信インターフェースを介して前記第1コントローラ及び前記ストレージデバイスと通信する第2コントローラとを有し、前記電子機器が前記複数の省電力状態のうちのいずれかの省電力状態に移行することに従って、前記第1コントローラは、前記移行する省電力状態に応じた省電力モードに前記第2コントローラを移行させ、省電力モードに移行した前記第2コントローラは、前記ストレージデバイスの電源をオフにし、且つ、前記電子機器が前記複数の省電力状態のうちのいずれかの省電力状態から復帰することに従って、前記第1コントローラは、前記第2コントローラを前記省電力モードから復帰させ、復帰した前記第2コントローラは、第1コマンドを受け付けたことに基づいて前記ストレージデバイスの電源をオンさせ、前記第1コマンドと異なる第2コマンドを受け付けたことに基づいて前記ストレージデバイスの電源をオンさせない。

20

## 【発明の効果】

## 【0008】

30

ストレージデバイス（例えばHDD）のオフ/オン回数に対する寿命を考慮しつつ効率的に消費電力を削減することができる。

## 【図面の簡単な説明】

## 【0009】

【図1】印刷システムの構成例を示す図である。

【図2】SATAブリッジ構成の接続例を示す図である。

【図3】SATAホスト制御部及びブリッジ制御部の内部構成例を示す図である。

【図4】PS0～PS2のSATA系省電力状態種類及び設定内容を示す図である。

【図5】省電力制御に関する拡張コマンド例を示す図である。

【図6】SATA系省電力設定への初期化フロー図である。

40

【図7】SATAホスト制御部の省電力移行処理フロー図である。

【図8】SATAブリッジ制御部の省電力移行処理フロー図である。

【図9】SATAホスト制御部の省電力状態からの復帰処理フロー図である。

【図10】SATAブリッジ制御部の省電力状態からの復帰処理フロー図である。

【図11】PS2省電状態からの復帰シーケンスを示したフロー図である。

【図12】SATAブリッジ制御部と電源制御部の接続例を示す図である。

【図13】HDDの電源制御タイミング例を示す図である。

【図14】デバイス接続状態の取得例を示す図である。

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

## 【0010】

50

図1は、本発明の実施形態による印刷システムの構成例を示す図である。印刷システムは、印刷装置及び外部HOSTコンピュータ107を有する。印刷装置は、メインコントローラ120と、スキャナ装置109と、HDD/SSD113, 114と、パネル装置116と、印刷部118とを有する。印刷装置は、電子機器である。以下、電子機器の例として、印刷装置について説明する。メインCPU(中央処理演算器)101は、メイン制御部であり、システム制御や各種演算処理を行う。メモリ制御部102は、各種メモリデバイスへの入出力制御やDMA(ダイレクト・メモリ・アクセス)制御を行う。フラッシュメモリ103は、書き換え可能な不揮発性メモリであり、システム全体の制御プログラムや制御パラメータ等が格納される。DRAM(ダイナミック・ランダム・アクセス・メモリ)104は、DDR(Double-Data-Rate)メモリに代表される揮発性の書き換え専用メモリである。DRAM104は、プログラムの作業領域や印刷データの格納領域、各種テーブル情報格納領域等の用途に用いられる。ここで、メモリ制御部102と各種メモリデバイスとの関係は、簡略化して表現したものであって、一般的には独立に制御される。LAN-IF制御部105は、印刷装置に接続されるローカル・エリア・ネットワーク106との入出力制御を行う。LAN-IF制御部105は、一般的にはTCP/IP(Transmission Control Protocol/Internet Protocol)プロトコルに対応する。LAN-IF制御部105は、ネットワークケーブルを介して外部HOSTコンピュータ107などのネットワーク対応機器と接続され、ネットワーク経由でのプリントを行うことができる。Reader-IF制御部108は、スキャナ装置109との通信制御を行う。印刷装置は、スキャナ装置109によってスキャンした入力画像データを印刷させることでコピー機能を実現する。画像処理部110は、LAN-IF制御部105、Reader-IF制御部108を介して取り込んだ画像データに対して各種画像処理を行う。SATAホスト制御部111は、SATA(Serial Advanced Technology Attachment)規格に準拠したIFを有するデバイスとのデータ入出力制御を行う。SATAプリッジ制御部112は、上流側としてSATAホスト制御部111にデバイスとして接続され、下流側としては複数のHost-IFを有し、HDD又はSSD113、114と接続される。SATAプリッジ制御部112は、RAID制御やデータ暗号化などの附加価値としての機能が搭載されている。SATA制御部121は、SATAホスト制御部111及びSATAプリッジ制御部112を有する通信制御手段であり、所定の通信規格に従う所定の物理通信インターフェースを介してメインCPU101及びデバイス113, 114と通信する。所定の通信規格は、例えばSATA規格である。本実施形態では、SATAホスト制御部111とSATAプリッジ制御部112は、それぞれ独立したASIC(特定用途向け集積回路)としてメインコントローラ120に搭載されていることを前提として説明を行う。パネルIF制御部115は、パネル装置116との通信制御を行う。パネル装置116は、UI(ユーザ・インターフェース)として、パネル上の液晶画面表示やボタン等を操作することにより印刷装置の各種設定及び状態の確認ができる。ビデオ出力IF部117は、印刷部118に対して、コマンド/ステータスの通信制御や印刷データの転送を行う。印刷部118は、印刷装置本体と給紙系及び排紙系から構成され、主にビデオ出力IF部117からのコマンド情報に従い、印刷データを紙に印刷する。メインバス119は、バスコントローラを含み、制御バス、データバス及び任意ロック間のローカルバスを便宜的にまとめて表現したものであり、代表例としてPCIe(PCI Express)やASICの内部バスなども含まれる。

#### 【0011】

図2は、SATAプリッジ構成の接続例を示す図である。メインASIC201は、SATAホスト制御部111を含むメインコントローラ120のシステム全体を制御する中心的なASICである。SATAホスト制御部111は、1個のSATA-IP(Intellectual Property)202をホストIFとして有する。サブASICは、SATAプリッジ制御部112そのものであり、メインコントローラ120上に独立したIC(Integrated Circuit)として実装されている。SATA

ブリッジ制御部 112 は、3 個の SATA - IP 203 ~ 205 を有する。ブリッジ構成の上流側では、SATA - IP (Host) 202 が H - Host - IF 206 を介して SATA - IP (Device) 203 と接続される。ブリッジ構成の下流側では、SATA - IP (Host 1) 204 が B - Host 1 - IF 207 を介して HDD / SSD 113 と接続され、SATA - IP (Host 2) 205 が B - Host 2 - IF 208 を介して HDD / SSD 114 と接続されている。ここで、SATA - IP 202 ~ 205 は、各種 SATA レジスタの設定に応じて SATA - IF 206 ~ 208 で接続される SATA デバイスに対して物理的な（電気信号としての）SATA 規格のコマンド発行やステータス受信を行う。

10

#### 【0012】

また、SATA ブリッジ制御部 112 は、電源制御部 209 と制御信号 214 で接続されている。電源制御部 209 は、メインボード上に搭載され、メインコントローラ 120 に含まれる各機能モジュールやそれに接続される各種装置への電力供給の有無を決定し、印刷装置全体としての電源制御を担っている。電源制御部 209 から出ている一点斜線 210 ~ 213 は、システム全体の部分である SATA ブリッジ部の各構成要素に対する電源ラインを示したものである。なお、本実施形態では、SATA ホスト制御部 111 及びブリッジ制御部 112 間の IF を 1 個、SATA ブリッジ制御部 112 及び HDD / SSD 113, 114 間の IF を 2 個として説明するが、各 IF の数は任意個数の接続形態であってもよい。

20

#### 【0013】

図 12 は、図 2 で接続構成を説明した SATA ブリッジ制御部 112 と電源制御部 209 間の HDD / SSD 電源制御を行う制御信号 214 を分解して、より詳細に示した図である。制御信号 IN 1205 は、SATA ブリッジ制御部 112 への入力信号であり、制御信号 OUT A1201 及び OUT B1202 は、電源制御部 209 への出力信号である。また、電源制御部 209 からは HDD / SSD へ電力を供給する電源回路 1204 への電力供給を許可する EN 信号 1203 が出力されている。電源回路 1204 は、例えば、DC - DC 電源（直流入力直流出力電源）や FET（電界効果トランジスタ）などが挙げられる。EN 信号 1203 は、制御信号 IN 1205 と接続されていて、HDD / SSD への電力供給状態、すなわち、電源オフかオンかの判定用モニタ信号として SATA ブリッジ制御部 112 に入力されている。制御信号 OUT A1201 及び OUT B1202 は、HDD / SSD の電源をオフ / オンするための電源制御部 209 への要求信号である。

30

#### 【0014】

図 13 は、制御信号 IN 1205、OUT A1201 及び OUT B1202 のタイミングチャートである。全ての信号は、開始点 1304 でローレベル開始処理されることを前提としている。制御信号 IN 1205 は、HDD / SSD の電源のオフ又はオン状態を示すモニタ信号であり、起動後、時点 1305 で HDD の電源オンとなったことを表している。制御信号 OUT A1201 は、電源制御部 209 に対して HDD / SSD 電源のオフ又はオン要求を行う有効期間を示す信号である。制御信号 OUT A1201 がハイレベルの区間 1306 ~ 1308 が電源制御部 209 に対して HDD / SSD 電源のオフ又はオンを要求する期間である。制御信号 OUT B1202 は、HDD / SSD 電源に対するオン又はオフ要求を行う信号であり、ハイレベル区間が電源オン要求を示し、ローレベル区間が電源オフ要求を示している。図 13 の例では、区間 1306 ~ 1307 では制御信号 OUT A がハイレベル、制御信号 OUT B がローレベルなので、HDD 電源がオフされる。区間 1306 ~ 1307 では、モニタ信号である制御信号 IN がローレベルとなっており、確かに HDD / SSD 電源はオフされていることが読み取れる。同様に、制御信号 OUT A がハイレベルの有効期間に制御信号 OUT B1202 をハイレベル / ローレベルにさせた結果に連動して、制御信号 IN 1205 がハイレベル / ローレベルになっていることが分かる。なお、図 12 及び図 13 を用いて説明した例では、モニタ信号である制御信号 IN 1205 及び電源オフ / オン要求信号である制御信号 OUT B1202 は 1 対 1 の

40

50

関係であったが、これに限定されない。SATAプリッジ制御部112に接続される複数のストレージデバイスのそれぞれに対してモニタ信号（＝電源EN信号）INnと電源オフ／オン要求信号OUTBn（n=2）として、同一番号nを対応させて個別に制御してもよい。

#### 【0015】

図3は、SATAホスト制御部111及びSATAプリッジ制御部112の内部構成例を示す図である。SATAホスト制御部111は、第1のSATA制御部であり、メインバス119を介してメインCPU101に接続される。SATAプリッジ制御部112は、第2のSATA制御部であり、H-Host-IF（第1のインターフェース）206を介してSATAホスト制御部111に接続される。HDD/SSD113は、デバイスであり、B-Host1-IF（第2のインターフェース）207を介してSATAプリッジ制御部112に接続される。HDD/SSD114は、デバイスであり、B-Host2-IF（第2のインターフェース）208を介してSATAプリッジ制御部112に接続される。

10

#### 【0016】

HCPU301は、SATAコマンド発行処理、送受信データの転送処理及びステータス受信処理等のSATAコントローラとしての全般的な制御を行う。メモリ制御部302は、フラッシュメモリ303やSRAM（スタティック・ランダム・アクセス・メモリ）304との入出力制御を行う。フラッシュメモリ303には、ブートプログラムやSATAコントローラとしての制御プログラムが格納されている。SRAM304は、HCPU301の作業領域、各種制御テーブルやパラメータ格納領域及びデータバッファなどに使用される。ここで、SRAM304は、1ポートRAM、2ポートRAM、 FIFO（First-IN First-OUT）メモリ等の制御を簡略化して記載しているのであって、それぞれ独立に制御され複数個所にSRAMが存在してもよい。割り込み制御部305は、HCPU301に対する割り込み信号の入力や出力処理、割り込み信号に対するマスク処理などを行う。レジスタH306は、省電力関連の制御パラメータなどを一時的に記憶するためのレジスタである。DMAC（ダイレクト・メモリ・アクセス・コントローラ）307は、HCPU301によって所定のレジスタに転送元及び転送先の先頭アドレス及びサイズが設定され、起動が掛けられると所定のメモリ間でデータ転送を行う。Hバス308は、バスコントローラを含み、制御バス、データバス及び任意ブロック間のローカルバスを便宜的にまとめて表現したものである。バスプリッジ回路309は、メインバス119とHバス308間のバスプロトコルを相互に変換するバスプリッジ回路である。

20

#### 【0017】

BCPU310は、SATAコマンド発行処理、送受信データの転送処理及びステータス受信処理等のSATAコントローラとしての全般的な制御を行う。メモリ制御部311は、フラッシュメモリ312やSRAM313との入出力制御を行う。フラッシュメモリ312には、ブートプログラムやSATAコントローラとしての制御プログラムが格納されている。SRAM313は、BCPU310の作業領域、各種制御テーブルやパラメータ格納領域及びデータバッファなどに使用される。ここで、SRAM313は、1ポートRAM、2ポートRAM、FIFOメモリ等の制御を簡略化して記載しているのであって、それぞれ独立に制御され複数個所にSRAMが存在してもよい。レジスタB314は、省電力関連の制御パラメータなどを一時的に記憶するためのレジスタである。電源IF部315は、電源制御部209と制御信号214で接続され、HDD/SSD113、114への電源オフ／オン要求信号の制御を行う。Others316は、SATAプリッジ制御部112としての他の機能ブロック、例えばRAID処理やデータ暗号化処理等をまとめて示したものである。Bバス317は、バスコントローラを含み、制御バス、データバス及び任意ブロック間のローカルバスを便宜的にまとめて表現したものである。また、図2で説明したように、SATAホスト制御部111のSATA-IP（Host）202とSATAプリッジ制御部112のSATA-IP（Device）203とは、H-

30

40

50

Host - IF 206 で接続されている。さらに、SATA - IP (Host 1/2) 204 及び 205 は、B - Host 1/2 - IF 207 及び 208 を介して、HDD / SSD 113 及び 114 に接続されている。

【0018】

図4は、メインコントローラ120の電力ステートを横軸に示し、SATA系省電力状態と省電力移行条件を縦軸として示したものである。図4の第1行目は、印刷装置全体としての上位電力ステート401を示しており、消費電力が高い順にStandby (スタンバイ) モード402、Sleep (スリープ) モード403、Deep (ディープ) モード404と定義する。Standby モード402は、印刷装置が直ちにジョブを受け付け可能な状態であり、図1のメインコントローラ120、スキヤナ装置109、パネル装置116、印刷部118及びHDD / SSD 113、114には全て通電され、基本的にアイドル状態である。Sleep モード403及びDeep モード404は、印刷装置の省電力状態であり、ジョブ実行をしていない期間の待機電力削減を目的とする。Sleep モード403では、Standby モード402で説明した部位は通電されているが、基本的に省電力状態である。特に、Deep モード404は、大半部分の電力供給をカットした状態であり、図1のメモリ制御部102及びDRAM104、LAN - IF 105、パネルIF 115及びパネル装置116に通電されている。Deep モード404は、Sleep モード403での各部省電力状態よりもさらに深い省電力状態に置かれ、それら以外は全て電源オフ状態である。本実施形態の対象であるSATAホスト制御部111、SATAブリッジ制御部112及び接続デバイスであるHDD / SSD 113、114も、Deep モード404では全て電源オフされた状態であることを前提としている。さらに、上位電力ステート401に対応するSATA系省電力状態としてPower Save 0 (PS0) 407、Power Save 1 (PS1) 408及びPower Save 2 (PS2) 409を定義する。PS0 (407) ~ PS2 (409) は、図4で示すように上位電力ステートに対応したものであり、電力削減効果としてはPS0 < PS1 < PS2 (電源オフ) の関係となる。また、そのトレードオフとして復帰時間は、不等号が逆転する関係となる。各SATA系省電力状態におけるH - Host - IF 206の省電力移行条件を項目411~413、B - Host 1/2 - IF 207及び208の省電力移行条件を項目415~417、HDD / SSD本体の省電力移行条件を項目419~421として定義する。各項目411~421の設定値で、図に“/”で区切られた内容は、その中のいずれかひとつが設定されることを示している。但し、設定値の個数（すなわち、とり得る状態数）は任意に追加してもよい。また、図4の省電力設定値としてのH - Host - IF 状態410、B - Host - IF 状態414、HDD / SSD本体状態418の対応個所を図2に示す。それらは、それぞれにH - Host - IF 206 (202及び203を含む)、B - Host 1/2 - IF 207及び208 (204及び205を含む)、HDD / SSD 113及び114に対応する。PS0 (407) ~ PS2 (409) の状態遷移した場合に項目411~421の設定値の状態に各対応部が置かれることを意味する。ここで、省電力移行条件としてとり得る省電力状態について説明する。AIはActive - Idle、LPIはLow - Power - Idleであり、アイドル状態におけるSATA - IFと接続デバイス本体のATA規格で定義されている電力状態を示す。既に説明したように、Partial / SlumberはSATA - IFとして、DevSleepはSATA - IF及びデバイス本体の両方の省電力状態をSATA規格で定義されたものである。また、Off Lineは、SATA - IPとしての無効（停止）状態を示す。一般的にSATA - IFの省電力として効果が高い順番に並べるとOff Line > DevSleep > Slumber > Partial > LPI > AI、同様にデバイス本体の省電力としては電源オフ > DevSleep > LPI > AIとなる。ここで、接続するデバイスの電源オフ指示の設定条件に、電源オフ - 1と電源オフ - 2を項目419及び420に設け、次の定義を与える。電源オフ - 1は、次回復帰時にデバイス本体の電源オンを伴わない（省電力 & 寿命優先）。電源オフ - 2は、次回復帰と同時にデバイス本体も電源オンする（利便性優先）。電源オフ - 1及び電源オフ - 2によって、特に

10

20

30

40

50

HDDの電源オフ／オン寿命を配慮した省電力制御が可能となる。後述するが、省電力移行条件は、SATAホスト制御部111及びSATAブリッジ制御部112の起動時に予め設定されることになる。また、SATAホスト制御部111のHCPUシステム及びSATAブリッジ制御部112のBCPUシステム自身の各省電力効果も一般的には復帰時間とのトレードオフとしてPS0 < PS1 < PS2（電源オフ）の関係と同じとするのが最適解である。ただし、PS0 = PS1 < PS2の関係でもよい。HCPU301及びBCPU310自身の省電力手段として、クロックゲートや電源分離による部分的な電源供給カットなどの方法がある。

#### 【0019】

ここで、図4で説明した例では、印刷装置全体の電力ステート数を3段階、それに対応するSATA系省電力状態を3段階としたが、電力ステート数やSATA系省電力状態数は任意であってよい。さらに、B-Host1/2-IF207及び208の省電力移行条件を項目415～417とし、HDD/SSD本体の省電力移行条件を項目419～421としてが、接続ポート単位で個別に設定してもよい。

10

#### 【0020】

図5は、図4で説明した各省電力移行条件を予めSATAブリッジ制御部112に設定するための拡張コマンドについて示す図である。SATA規格で定義された空コマンドであるベンダユニーク・コマンド（例えばF0h）に対して、図5の第1行目左から示されるように拡張コマンド名称501、CMD（サブコマンド）番号502、転送タイプ503として省電力系拡張コマンドを独自に定義する。ここで、CMD番号502は、ベンダユニーク・コマンド（例えば、F0h）に対するFeatureレジスタに設定されるサブコマンド番号を示す。また、SATA規格では、基本的な転送タイプとして、データを伴わないNon-Data（ND）転送、単発データ転送を実行するPIO-In（PI）又はPIO-Out（PO）転送、連続データ転送を実行するDMA転送などの転送タイプが定義されている。図5での転送タイプ503は、CMD番号502に対する転送タイプを定義している。例えば、SetupPowerConfigコマンド505は、CMD番号が01h（506）、転送タイプがPO（507）で構成される。同様に、ToSleepコマンド509は、CMD番号が02h（510）、転送タイプがND（511）で定義されている。ToDeepコマンド513は、CMD番号が03h（514）、転送タイプがND（515）で定義されている。GetStatusコマンド517は、CMD番号が04h（518）、転送タイプがPI（519）で定義されている。

20

#### 【0021】

SetupPowerConfigコマンド505は、指定内容508に示すように、SATAブリッジ制御部112に、H-Host-IF206の省電力移行条件411～413を設定するために用いられる。また、SetupPowerConfigコマンド505は、指定内容508に示すように、SATAブリッジ制御部112に、B-Host1/2-IF207及び208の省電力移行条件415～417を設定するために用いられる。また、SetupPowerConfigコマンド505は、指定内容508に示すように、SATAブリッジ制御部112に、HDD/SSD本体の省電力移行条件419～421を設定するために用いられる。

30

#### 【0022】

ToSleepコマンド509は、指定内容512に示すように、上位電力ステートがSleepモード403へ移行することをSATAブリッジ制御部112に通知するコマンドである。ToDeepコマンド513は、指定内容516に示すように、上位電力ステートがDeepモードに移行することをSATAブリッジ制御部112に通知するコマンドである。GetStatusコマンド517は、指定内容520に示すように、SATAブリッジ制御部全般のステータス取得のための拡張コマンドである。これは、直接的な省電力関連の拡張コマンドではないが、例えば省電力移行処理が完了したことを上位システムが取得する場合に用いられる。以後、拡張コマンド以外のATA規格で定義されたコマンドを区別して表現する場合には、ATAコマンドと呼ぶことにする。

40

50

## 【0023】

さらに、幾つかのフロー図を用いて、本実施形態の印刷装置（電子機器）の制御方法について説明する。なお、説明の煩雑性を避けるため、本実施形態に関係しないエラー処理については基本的に説明を省略する。

## 【0024】

図6は、SATA系省電力制御の初期設定フローを示す図である。メインコントローラ120の起動（コールドブート）時に、以下の処理が行われる。ステップS601では、メインCPU101は、SATAホスト制御部111に対して、複数の省電力状態PS0～PS2毎に、図4で説明したH-Host-IF206の省電力移行条件411～413の設定を行う。次に、ステップS602では、メインCPU101は、SATAブリッジ制御部112に対して、SetupPowerConfigコマンド505をSATAホスト制御部111から発行することで、省電力の初期設定を行う。具体的には、メインCPU101は、SATAブリッジ制御部112に対して、複数の省電力状態PS0～PS2毎に、図4で説明したB-Host1/2-IF207及び208の省電力移行条件415～417を設定する。また、メインCPU101は、SATAブリッジ制御部112に対して、複数の省電力状態PS0～PS2毎に、図4で説明したHDD/SSD113及び114の省電力移行条件419～421を設定する。SetupPowerConfigコマンド505を受信したBCPU310は、所定の場所に省電力移行条件を記録する。ここで、SATAホスト制御部111及びSATAブリッジ制御部112における省電力移行条件の記録場所としてはレジスタH306やレジスタB314、SRAM304や313、フラッシュメモリ303や312などに設定を行う。この際、省電力移行処理時に読み出せる場所であれば特に限定はしない。また、上記ではメインコントローラ120起動時の初期設定について説明したが、印刷装置がStandbyモード402であれば、同じ設定方法によって任意タイミングで省電力移行条件を再設定してもよい。なお、本実施形態での印刷装置の起動（コールドブート）時は、一端上位電力ステートがStandbyモード402、SATA制御系及びそれに接続されるストレージデバイスがアイドル状態に遷移することを前提とする。

## 【0025】

図7は、SATAホスト制御部111の省電力移行シーケンスを示す図である。ステップS701では、HCPU301は、アイドル（待機）状態としてメインCPU101からの割り込み指示待ちである。次に、ステップS702では、メインCPU101は、SATAホスト制御部111に対して、アイドル状態から、省電力効果が異なる複数の省電力状態PS0, PS1, PS2のうちの1つの省電力状態への移行要求割り込みを指示する。HCPU301は、受信した割り込み信号の判定を行う。HCPU301は、その判定結果がPS0移行要求割り込みである（YES）場合には、ステップS703に処理を進め、その判定結果がPS0移行要求割り込みでない（NO）場合には、ステップS705に処理を進める。ステップS703では、HCPU301は、図6のステップS601の設定に応じて、H-Host-IF206に対してアイドル状態から省電力状態PS0（407）への移行処理を行う。すなわち、HCPU301は、SATAブリッジ制御部112に対してアイドル状態から省電力状態PS0への移行を指示する。次に、ステップS704では、HCPU301は、SATAホスト制御部111自身に対してアイドル状態から省電力状態PS0（407）への移行処理を行う。

## 【0026】

ステップS705では、HCPU301は、判定結果がPS1移行要求割り込みである（YES）場合には、ステップS706に処理を進め、判定結果がPS1移行要求割り込みでない（NO）場合には、ステップS708に処理を進める。ステップS706では、HCPU301は、図6のステップS601の設定に応じて、H-Host-IF206に対してアイドル状態から省電力状態PS1（408）への移行処理を行う。すなわち、HCPU301は、SATAブリッジ制御部112に対してアイドル状態から省電力状態PS1への移行を指示する。次に、ステップS707では、HCPU301は、SAT

A ホスト制御部 111 自身に対して、アイドル状態から省電力状態 PS1 (408) への移行処理を行う。

#### 【0027】

ステップ S708 では、HCPU301 は、判定結果が PS2 移行要求割り込みである (YES) 場合には、ステップ S709 に処理を進め、判定結果が PS2 移行要求割り込みでない (NO) 場合には、ステップ S711 に処理を進める。ステップ S709 では、HCPU301 は、図 6 のステップ S601 の設定に応じて、H-Host-IF206 に対して、アイドル状態から省電力状態を PS2 (409) への移行処理を行う。すなわち、HCPU301 は、SATA ブリッジ制御部 112 に対してアイドル状態から省電力状態 PS2 への移行を指示する。次に、ステップ S710 では、HCPU301 は、SATA ホスト制御部 111 自身に対して、アイドル状態から省電力状態 PS2 (409) への移行処理を行う。10

#### 【0028】

ステップ S711 では、HCPU301 は、省電力移行要求以外の割り込みに応じた処理、例えば通常データ転送時のライトコマンド発行処理などを実行し、処理完了した後に再びステップ S701 に戻り、アイドル状態に入る。なお、HCPU301 は、要求のあった省電力状態に移行した後に、移行完了割り込みをメイン CPU101 に通知すると同時に、レジスタ H306 の一部を省電力状態のステータスレジスタとして報告する。

#### 【0029】

ここで、PS0 (407) ~ PS2 (409) での設定された H-Host-IF206 の省電力移行条件について説明する。Partial 及び S1umber は、SATA 規格で定義されたリクエストパケットを送信し、送信先が許可すれば SATA-IF に対する省電力状態に入ることができる。また、DevSleep は、まず SATA-IF を S1umber に入れて、さらにシングルエンド信号である DEVSLEEP 信号をイネーブル状態にすることで接続デバイス本体電力を削減することができる。20

#### 【0030】

図 8 は、SATA ブリッジ制御部 112 の省電力移行シーケンスを示す図である。ステップ S801 では、BCPU310 は、アイドル状態として待機中である。BCPU310 は、基本的に SATA ホスト制御部 111 である HCPU301 からの割り込み指示待ちの状態である。次に、ステップ S802 では、BCPU310 は、受信した割り込み信号が H-Host-IF206 の省電力状態への移行の通知 (移行を引き起こすイベントが発生した) かどうかの判定を行う。BCPU310 は、判定結果が H-Host-IF206 の省電力状態への移行の通知である (YES) 場合には、ステップ S809 に処理を進める。また、BCPU310 は、判定結果が H-Host-IF206 の省電力状態への移行の通知でない (NO) 場合には、ステップ S803 に処理を進める。30

#### 【0031】

ステップ S803 では、BCPU310 は、受信した割り込み信号が省電力系の拡張コマンドであるかどうかの判定を行う。BCPU310 は、省電力系の拡張コマンドである (YES) の場合には、ステップ S805 に処理を進め、省電力系の拡張コマンドでない (NO) の場合には、ステップ S804 に処理を進める。ステップ S804 では、BCPU310 は、他の割り込み処理、例えば ATA コマンド処理などを実行し、再びステップ S801 のアイドル状態に戻る。40

#### 【0032】

ステップ S805 では、BCPU301 は、受信した省電力系コマンドが Tosleep コマンド 509 かどうかの判定を行う。BCPU301 は、Tosleep コマンド 509 である (YES) の場合には、ステップ S806 に処理を進め、Tosleep コマンド 509 でない (NO) の場合には、ステップ S807 に処理を進める。ステップ S806 では、BCPU310 は、上位電力ステートを Sleep モード 403 としてレジスタ B314 や SRAM313 等に登録し、再びステップ S801 のアイドル状態に戻る。

#### 【0033】

10

20

30

40

50

ステップ S 807 では、B C P U 310 は、受信した省電力系コマンドが T o D e e p コマンド 513 であると判断し、上位電力ステートを Deep モード 403 としてレジスタ B314 や S R A M 313 等に登録し、ステップ S 808 へ処理を進める。ステップ S 808 では、B C P U 310 は、Deep 移行準備を行い、再びステップ S 801 のアイドル状態に戻る。Deep モード 403 では、基本的に電源制御部 209 による電源オフ処理を前提としている。そのため、特に瞬断を許さないストレージデバイス (HDD や SSD) 及びフラッシュメモリを内蔵する S A T A ブリッジ制御部 112 のようなタイプの I C は電源オフ準備を行い、準備完了後に電源オフタイミングを通知する必要がある。P S 2 状態としての電源オフ準備完了かどうかは、G e t S t a t u s コマンド 517 によって取得することが可能である。メイン C P U 101 は、S A T A ホスト制御部 111 や S A T A ブリッジ制御部 112 が電源オフ準備完了したことを前述したステータス取得手段により確認した後に、電源制御部 209 に電源オフ許可を通知する。また、一例として HDD 電源オフ時の準備としては、A T A 規格の F L U S H C A C H E コマンド及び S L E E P コマンドを発行し、データ退避や物理的なヘッダの退避等を行う。

#### 【0034】

ステップ S 809 では、B C P U 310 は、上位電力ステートが S t a n d b y モード 402 として予め設定されている H - H o s t - I F 206 の省電力移行条件 411 から、P S 0 (407) に移行すべきかどうかの判定を行う。B C P U 310 は、P S 0 (407) に移行すべき (Y E S) 場合には、ステップ S 810 に処理を進め、P S 0 (407) に移行すべきでない (N O) 場合には、ステップ S 811 に処理を進める。ステップ S 810 では、B C P U 310 は、予め設定されている B - H o s t 1 / 2 - I F 207 及び 208 の省電力移行条件 415 を基に、B - H o s t 1 / 2 - I F 207 及び 208 に対してアイドル状態から省電力状態 P S 0 (407) への移行処理を行う。また、B C P U 310 は、予め設定されている HDD / S S D 本体の省電力移行条件 419 を基に、H D D / S S D 113, 114 に対してアイドル状態から省電力状態 P S 0 (407) への移行処理を行う。例えば、B C P U 310 は、電源オフ - 1 (第 1 の電源オフモード) 又は電源オフ - 2 (第 2 の電源オフモード) で H D D / S S D 113, 114 の電源オフを指示する。そして、B C P U 310 は、S A T A ブリッジ制御部 112 自身に対してアイドル状態から省電力状態 P S 0 (407) への移行処理を行う。

#### 【0035】

ステップ S 811 では、B C P U 310 は、上位電力ステートが S l e e p モード 403 として予め設定されている H - H o s t - I F 206 の省電力移行条件 412 から、P S 1 (408) に移行すべきかどうかの判定を行う。B C P U 310 は、P S 1 (408) に移行すべき (Y E S) 場合には、ステップ S 812 に処理を進め、P S 1 (408) に移行すべきでない (N O) 場合には、ステップ S 813 に処理を進める。ステップ S 812 では、B C P U 310 は、予め設定されている B - H o s t 1 / 2 - I F 207 及び 208 の省電力移行条件 416 を基に、B - H o s t 1 / 2 - I F 207 及び 208 に対してアイドル状態から省電力状態 P S 1 (408) への移行処理を行う。また、B C P U 310 は、予め設定されている HDD / S S D 本体の省電力移行条件 420 を基に、H D D / S S D 113, 114 に対してアイドル状態から省電力状態 P S 1 (408) への移行処理を行う。例えば、B C P U 310 は、電源オフ - 1 (第 1 の電源オフモード) 又は電源オフ - 2 (第 2 の電源オフモード) で H D D / S S D 113, 114 の電源オフを指示する。そして、B C P U 310 は、S A T A ブリッジ制御部 112 自身に対して、アイドル状態から省電力状態 P S 1 (408) への移行処理を行う。

#### 【0036】

ステップ S 813 では、B C P U 310 は、上位電力ステートが Deep モード 404 として予め設定されている H - H o s t - I F 206 の省電力移行条件 413 から、P S 2 (409) に移行すべきかどうかの判定を行う。B C P U 310 は、P S 2 (409) に移行すべき (Y E S) 場合には、ステップ S 814 に処理を進め、P S 2 (409) に移行すべきでない (N O) 場合には、ステップ S 815 に処理を進める。ステップ S 81

4では、B C P U 3 1 0は、予め設定されているB - H o s t 1 / 2 - I F 2 0 7及び208の省電力移行条件417を基に、B - H o s t 1 / 2 - I F 2 0 7及び208に対してアイドル状態から省電力状態P S 2 ( 4 0 9 )への移行処理を行う。また、B C P U 3 1 0は、予め設定されているH D D / S S D本体の省電力移行条件421を基に、H D D / S S D 1 1 3 , 1 1 4に対してアイドル状態から省電力状態P S 2 ( 4 0 9 )への移行処理を行う。そして、B C P U 3 1 0は、S A T Aブリッジ制御部112自身に対して、アイドル状態から省電力状態P S 2 ( 4 0 9 )への移行処理を行う。ステップS 8 1 5では、B C P U 3 1 0は、省電力移行失敗としてエラー処理を行い、上位へのステータス通知等を実行する。

## 【0037】

10

以上のように、S A T Aブリッジ制御部112は、P S 0 ( 4 0 7 ) ~ P S 2 ( 4 0 9 )のいずれかの省電力状態への移行判定を行う。その際、S A T Aブリッジ制御部112は、上位電力ステート( S t a n d b y モード402、S l e e p モード403、D e e p モード404)情報とH - H o s t - I F 2 0 6の省電力状態の2条件からP S 0 ~ P S 2のいずれかであるかを判定する。P S 0又はP S 1で、H D D / S S D本体の省電力移行条件419 ~ 421が電源オフ指示(電源オフ - 1又は電源オフ - 2)であった場合には、図12及び図13で説明したようにB C P U 3 1 0は、電源制御部209にH D D / S S D電源のオフ要求を行う。

## 【0038】

20

図9は、S A T Aホスト制御部111のP S 0 ( 4 0 7 )又はP S 1 ( 4 0 8 )からの復帰シーケンスを示す図である。ステップS 9 0 1では、H C P U 3 0 1は、P S 0又はP S 1の省電力状態である。次に、ステップS 9 0 2では、H C P U 3 0 1は、メインC P U 1 0 1からの割り込み要求待ち状態であり、割り込み要求がなければ( すなわち、S 9 0 2のN Oであれば )、ステップS 9 0 1に戻り、P S 0又はP S 1の省電力状態を継続する。H C P U 3 0 1は、コマンド転送要求割り込みを受信すると、ステップS 9 0 3へ処理を進める。すなわち、H C P U 3 0 1は、メインC P U 1 0 1により省電力状態P S 0又はP S 1からアイドル状態への復帰が指示されると、ステップS 9 0 3に処理を進める。ステップS 9 0 3では、H C P U 3 0 1は、S A T Aホスト制御部111自身に対して省電力状態P S 0又はP S 1からアイドル状態への復帰処理を行う。次に、ステップS 9 0 4では、H C P U 3 0 1は、H - H o s t - I F 2 0 6に対して、省電力状態P S 0又はP S 1からアイドル状態への復帰処理を行う。具体的には、H C P U 3 0 1は、S A T A規格で規定されたO O B ( O u t O f B a n d )やスピードネゴシエーションの所定シーケンスを経て、コマンド発行可能となるまでのリンク確立処理を行う。ここでの、基本的にS A T A - I F系省電力状態からの復帰は、S A T A規格で定義されたリセット信号であるC o m R e s e t 信号の発行から開始される。D e v S l e e pからの復帰は、図7で説明した移行の逆手順で、まずD E V S L P信号をディスイネーブルにしてから、次にC o m R e s e t 信号( 又はC o m W a k e 信号 )を投げることで開始される。次に、ステップS 9 0 5では、H C P U 3 0 1は、リンク確立したことを確認すると、メインC P U 1 0 1からの要求コマンドをH - H o s t - I F 2 0 6に発行する。次に、ステップS 9 0 6では、H C P U 3 0 1は、S A T A - I P ( D e v i c e ) 2 0 3からのS t a t u s 受信待ちに入る。H C P U 3 0 1は、未受信の間( S 9 0 6でN O )はそのまま待機し、S t a t u s を受信( S 9 0 6でY E S )した時点で、一連のコマンド処理を終了し、ステップS 9 0 7に処理を進める。ステップS 9 0 7では、メインC P U 1 0 1によって再び省電力移行要求が発行されるまでの間、S A T Aホスト制御部111は、アイドル状態を維持する。

30

## 【0039】

40

図10は、S A T Aブリッジ制御部112のP S 0 ( 4 0 7 )又はP S 1 ( 4 0 8 )からの復帰シーケンスを示す図である。ステップS 1 0 0 1では、B C P U 3 1 0は、P S 0又はP S 1の省電力状態である。次に、ステップS 1 0 0 2では、B C P U 3 1 0は、割り込み要求待ち状態であり、割り込み要求がなければ( すなわち、S 1 0 0 2のN Oで

50

あれば)、ステップS1001に戻り、PS0又はPS1の省電力状態を継続する。BCP310は、H-Host-IF206のアイドル状態への復帰処理開始の割り込みを受信(S1002でYES)すると、ステップS1003に処理を進める。すなわち、BCP310は、省電力状態からの復帰を引き起こすイベントが発生すると、ステップS1003に処理を進める。ここで、復帰処理の開始は、図9で説明したDEVS LP信号がディイネーブルとなるレベル変化の検知やComReset(又はComWake)を要因として割り込み信号が発行される。ステップS1003では、BCP310は、SATAブリッジ制御部112自身に対して省電力状態PS0又はPS1からアイドル状態への復帰処理を行う。次に、ステップS1004では、BCP310は、H-Host-IF206に対して省電力状態PS0又はPS1からアイドル状態への復帰処理を行う。具体的には、BCP310は、SATA規格で規定されたOOB(Out of Band)やスピードネゴシエーションの所定シーケンスを経て、コマンド発行可能となるまでのリンク確立処理を行う。  
10

#### 【0040】

次に、ステップS1005では、BCP310は、前回の省電力移行時のデバイス本体移行設定条件が電源オフ-2であったかどうかの判定を行う。ここで、BCP310は、前回の省電力移行時のデバイス本体の移行設定条件が電源オフ-1又は電源オフ-2なのかを、次回復帰時に判定可能なように記録しておく必要がある。PS0(407)やPS1(408)では、少なくともHCP301やBCP310のSATA制御部は省電力状態には移行するが、電源オフにはならないことを前提としている。従って、電源オフ-1か電源オフ-2の判定情報を、例えばレジスタH306やレジスタB314などに記録することが可能である。記録は、次回省電力からの復帰時のみ利用され、復帰した後にクリアされるものとする。BCP310は、電源オフ-2であった(YES)場合(且つ、IN1205がローレベル)には、ステップS1006に処理を進め、電源オフ-2でなかった(NO)場合には、ステップS1008に処理を進める。すなわち、BCP310は、電源オフの指示内容に基づきステップS1006に進むか否かを決定する。  
20

#### 【0041】

ステップS1006では、BCP310は、接続デバイスに対して省電力状態PS0又はPS1からアイドル状態への復帰処理を行う。BCP310は、接続デバイスであるHDD/SSD113、114の電源をオフしていた場合、図12及び図13で説明したように電源制御部209に対してHDD/SSD電源のオン要求を行う。すなわち、BCP310は、電源オフ-2である場合にはHDD/SSD113、114の電源オンを指示し、電源オフ-1である場合にはHDD/SSD113、114の電源オフを指示しない。  
30

#### 【0042】

次に、ステップS1007では、BCP310は、B-Host1/2-IF207及び208に対して省電力状態PS0又はPS1からアイドル状態への復帰処理を行い、ステップS1008に処理を進める。復帰処理に関しては、図9で説明したH-Host-IF206の復帰処理と同様である。  
40

#### 【0043】

ステップS1008では、BCP310は、リンク確立したことを確認すると、コマンド受信待ちを開始する。この時点で省電力状態からアイドル状態への復帰は完了したことになる。BCP310は、コマンドを受信していない(NO)場合には、ステップS1008に留まり、受信した(YES)場合には、ステップS1009へ処理を進める。

#### 【0044】

ステップS1009では、BCP310は、SATAホスト制御部111から受信したコマンドがATAコマンドかどうかの判定を行う。BCP310は、ATAコマンドである(YES)場合には、ステップS1011に処理を進め、ATAコマンドでない(NO)場合には、ステップS1010に処理を進める。ステップS1011では、BCP  
50

U310は、前回の省電力移行時のデバイス本体移行設定条件が電源オフ - 1であったかどうかの判定を行う。BCPU310は、電源オフ - 1であった場合（且つ、IN1205がローレベル）には、ステップS1012に処理を進め、電源オフ - 1でなかった場合には、ステップS1014に処理を進める。

#### 【0045】

ステップS1012では、BCPU310は、ステップS1006と同様に、接続デバイスであるHDD/SSD113、114に対して省電力状態PS0又はPS1からアイドル状態への復帰処理を行う。BCPU310は、電源オフ - 1である場合には、HDD/SSD113、114の電源オンを指示する。次に、ステップS1013では、BCPU310は、ステップS1007と同様に、B-Host1/2-IF207及び208に対して省電力状態PS0又はPS1からアイドル状態への復帰処理を行い、ステップS1014に処理を進める。  
10

#### 【0046】

ステップS1014では、BCPU310は、ATAコマンドの処理を行う。次に、S1015では、HCPU301は、HDD/SSD113、114からのStatus受信待ちに入る。HCPU301は、未受信の間（S1015でNO）はそのまま待機し、Statusを受信（S1015でYES）した時点で、ステップS1016に処理を進める。

#### 【0047】

また、ステップS1009では、BCPU310は、受信コマンドが拡張コマンドである場合には、ステップS1010に処理を進める。ステップS1010では、BCPU310は、拡張コマンド処理を実行し、ステップS1016に処理を進める。  
20

#### 【0048】

ステップS1016では、BCPU310は、HDD/SSDから受信したステータス情報又は拡張コマンドにて処理した結果を、SATA規格で定義されたステータスパケットに反映してSATA-IP（Host）201へ送信する。これにより、BCPU310は、一連のコマンド処理を終了する。次に、ステップS1017では、メインCPU101によって再び省電力移行要求が発行されるまでの間、SATAブリッジ制御部112はアイドル状態を維持する。

#### 【0049】

図11は、SATAブリッジ制御部112のPS2（409）省電力状態からの復帰シーケンスを示す図である。ここでの説明では、接続デバイスとしてHDDを前提として説明を行う。ステップS1101では、HCPU301及びBCPU310は、前回のPS2移行処理により電源オフ状態である。その後、電源制御部209は、SATAホスト制御部111及びSATAブリッジ制御部112への電源供給（すなわち、電源オン）を開始する。次に、ステップS1102では、BCPU310は、自身の復帰処理（ブート処理）を実施する。次に、ステップS1103では、BCPU310は、H-Host-IF206の復帰処理を実行する。具体的には、BCPU310のブート処理と同時にHCPU301のブート処理も開始される。H-Host-IF206の復帰処理では、既に説明したようにSATA-IP（Host）202からSATA-IP（Device）203へのComRest信号を基点としたOOB及びスピードネゴシエーション処理を経てリンクが確立される。ステップS1103でのリンク確立後、BCPU310は、SATA下層のリンク確立を実行する。次に、ステップS1104では、BCPU310は、HDD電源供給状態をモニタする制御信号IN1205を確認し、HDD電源のオフ/オン判定を行う。BCPU310は、制御信号INがハイレベルである（YES）場合には、ステップS1105に処理を進め、制御信号INがローレベルである（NO）場合には、ステップS1106に処理を進める。  
40

#### 【0050】

ステップS1105では、BCPU310は、電源オフ - 2（電源オンを伴う復帰）と認識し、ステップS1107に処理を進める。ステップS1106では、BCPU310  
50

は、電源オフ - 1 (電源オンを伴わない復帰) として認識し、ステップ S 1107 に処理を進める。ここで、Get Status 517 では、省電力への移行確認だけでなく、HDD の接続状況なども取得可能である。メイン CPU 101 は、SATA ホスト制御部 111 及び SATA ブリッジ制御部 112 の起動後、所定時間内に HDD 接続 OK (リンク確立状態) とならない場合にはエラーとして扱う。ここで、Get Status 517 の HDD 接続状態確認では、例えば未接続状態 1 (接続エラー) / 未接続状態 2 (電源オフ - 1 としての未接続) を区別して確認できるようにする。

#### 【0051】

図 14 は、Get Status 517 で報告される一例を示す。Get Status 517 での報告内容 1401 の一部として、デバイス 1 接続状態 1402 とデバイス 2 接続状態 1403 とを設け、さらに状態定義 1404 を示す。例えば、意図的な電源オフ状態での復帰時は “状態 : 01” としてメイン CPU 101 に報告される。BCPU 310 は、ステップ S 1105 又は S 1106 での認識によって、Get Status 517 での HDD 接続状態報告を未接続 2 として適切に示すことができる。未接続 2 を確認したメイン CPU 101 は、この場合、意図的な未接続として認識し、エラー処理対象としない。

#### 【0052】

ステップ S 1107 では、BCPU 310 は、上位層がリンク確立したことを確認すると、コマンドの受信待ちを開始する。この時点で省電力状態からアイドル状態への復帰は完了したことになる。BCPU 310 は、コマンド未受信の間 (NO) はステップ S 1107 に滞在し、コマンドを受信する (YES) と、ステップ S 1108 に処理を進める。

#### 【0053】

ステップ S 1108 では、BCPU 310 は、受信したコマンドが ATA コマンドかどうかの判定を行う。BCPU 310 は、ATA コマンドである (YES) 場合には、ステップ S 1110 に処理を進め、拡張コマンドである (NO) 場合には、ステップ S 1109 に処理を進める。

#### 【0054】

ステップ S 1110 では、BCPU 310 は、HDD 電源供給状態をモニタする制御信号 IN1205 を確認し、HDD 電源のオフ / オン判定を行う。BCPU 310 は、制御信号 IN1205 がローレベルである (YES) 場合には、ステップ S 1111 に処理を進め、制御信号 IN1205 がハイレベルである (NO) 場合には、ステップ S 1113 に処理を進める。ステップ S 1111 では、BCPU 310 は、ステップ S 1006 と同様に、接続デバイスの復帰処理を行う。次に、ステップ S 1112 では、BCPU 310 は、ステップ S 1007 と同様に、B-Host1/2-IF207 及び 208 の復帰処理を行い、ステップ S 1113 に処理を進める。

#### 【0055】

ステップ S 1113 では、BCPU 310 は、ATA コマンド処理を実行する。次に、ステップ S 1114 では、HCPU 301 は、HDD113、114 からの Status 受信待ちに入る。HCPU 301 は、未受信の間 (S1114 で NO) はそのまま待機し、Status を受信 (S1114 で YES) した時点で、ステップ S 1115 に処理を進める。また、ステップ S 1109 では、BCPU 310 は、拡張コマンド処理を実行し、ステップ S 1115 に処理を進める。

#### 【0056】

ステップ S 1115 では、BCPU 310 は、HDD113、114 から受信したステータス情報又は拡張コマンドにて処理した結果を、SATA 規格で定義されたステータスパケットに反映して SATA - IP (Host) 201 へ送信する。これにより、BCPU 310 は、一連のコマンド処理を終了する。次に、ステップ S 1116 では、メイン CPU 101 によって再び省電力移行要求が発行されるまでの間、SATA ブリッジ制御部 112 はアイドル状態を維持する。

#### 【0057】

以上のように、本実施形態では、アイドル状態及び省電力状態 (PS0 ~ PS2) 間、

10

20

30

40

50

省電力状態間（例えば、PS1及びPS2間）の遷移で、特にHDDにおいて移行条件に電源オフ-1を設定しておく。これにより、ATAコマンド受信時（すなわち、真にHDDを必要とする場合）のみにHDD電源オン制御可能となるため、HDDに対する省電力的、且つ電源オフ／オン回数寿命的にも最適な省電力制御を実施することが可能となる。

【 0 0 5 8 】

なお、上記実施形態は、何れも本発明を実施するにあたっての具体化の例を示したものに過ぎず、これらによって本発明の技術的範囲が限定的に解釈されてはならないものである。すなわち、本発明はその技術思想、又はその主要な特徴から逸脱することなく、様々な形で実施することができる。

### 【符号の説明】

【 0 0 5 9 】

101 メインCPU、111 SATAホスト制御部、112 SATAブリッジ制御部、113, 114 HDD/SSD

10

( 1 )



〔 図 2 〕



【図3】



【図4】



【図5】

| 拡張コマンド名          | CMD番号 | 伝送タイプ | 指定内容                                                                                                                      |
|------------------|-------|-------|---------------------------------------------------------------------------------------------------------------------------|
| SetupPowerConfig | 01h   | PO    | PS/PS/PSの各省電力モード固別に、<br>・H-Host-IFの省電力状態及びB-Host1-IFに接続されるデバイス本体の省電力状態<br>・B-Host1-IFの省電力状態及びB-Host2-IFに接続されるデバイス本体の省電力状態 |
| ToSleep          | 02h   | ND    | 上位電力ステートが"Sleep"状態に移行することを通知                                                                                              |
| ToDeep           | 03h   | ND    | 上位電力ステートが"Deep"状態に移行することを通知                                                                                               |
| GetStatus        | 04h   | PI    | SATAプリッジ制御部のステータス取得                                                                                                       |
|                  | 501   |       |                                                                                                                           |
|                  | 502   |       |                                                                                                                           |
|                  | 503   |       |                                                                                                                           |
|                  | 504   |       |                                                                                                                           |
|                  | 505   |       |                                                                                                                           |
|                  | 506   |       |                                                                                                                           |
|                  | 507   |       |                                                                                                                           |
|                  | 508   |       |                                                                                                                           |
|                  | 509   |       |                                                                                                                           |
|                  | 510   |       |                                                                                                                           |
|                  | 511   |       |                                                                                                                           |
|                  | 512   |       |                                                                                                                           |
|                  | 513   |       |                                                                                                                           |
|                  | 514   |       |                                                                                                                           |
|                  | 515   |       |                                                                                                                           |
|                  | 516   |       |                                                                                                                           |
|                  | 517   |       |                                                                                                                           |
|                  | 518   |       |                                                                                                                           |
|                  | 519   |       |                                                                                                                           |

【図6】



【図7】



【図8】



【図9】



【図10】



【図11】



【図12】



【図13】



【図14】



---

フロントページの続き

(56)参考文献 特開2014-045302(JP, A)  
特開2015-208909(JP, A)  
特開2014-057134(JP, A)  
米国特許出願公開第2015/0026493(US, A1)

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

|        |           |
|--------|-----------|
| B 41 J | 2 9 / 3 8 |
| G 06 F | 1 / 3 2   |
| H 04 N | 1 / 0 0   |