

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

## (12) 公表特許公報(A)

(11) 特許出願公表番号

特表2008-516310  
(P2008-516310A)

(43) 公表日 平成20年5月15日(2008.5.15)

| (51) Int.Cl.                | F 1        | テーマコード (参考) |
|-----------------------------|------------|-------------|
| <b>G06F 17/50</b> (2006.01) | G06F 17/50 | 5 B 017     |
| <b>G06F 21/24</b> (2006.01) | G06F 12/14 | 5 B 046     |
| <b>H04L 9/32</b> (2006.01)  | G06F 12/14 | 5 J 104     |
|                             | G06F 12/14 | 5 4 O A     |
|                             | G06F 12/14 | 5 2 O F     |

審査請求 未請求 予備審査請求 未請求 (全 30 頁) 最終頁に続く

|               |                              |          |                                                                                                  |
|---------------|------------------------------|----------|--------------------------------------------------------------------------------------------------|
| (21) 出願番号     | 特願2007-534713 (P2007-534713) | (71) 出願人 | 507103503<br>シンプリシティー インコーポレイテッド<br>アメリカ合衆国 カリフォルニア州 94<br>086 サニーベイル ウエスト カリ<br>フォルニア ストリート 600 |
| (86) (22) 出願日 | 平成17年9月28日 (2005. 9. 28)     | (74) 代理人 | 100082005<br>弁理士 熊倉 穎男                                                                           |
| (85) 翻訳文提出日   | 平成19年5月25日 (2007. 5. 25)     | (74) 代理人 | 100067013<br>弁理士 大塚 文昭                                                                           |
| (86) 國際出願番号   | PCT/US2005/034637            | (74) 代理人 | 100086771<br>弁理士 西島 幸喜                                                                           |
| (87) 國際公開番号   | W02006/039286                | (74) 代理人 | 100109070<br>弁理士 須田 洋之                                                                           |
| (87) 國際公開日    | 平成18年4月13日 (2006. 4. 13)     |          |                                                                                                  |
| (31) 優先権主張番号  | 10/956, 327                  |          |                                                                                                  |
| (32) 優先日      | 平成16年9月30日 (2004. 9. 30)     |          |                                                                                                  |
| (33) 優先権主張国   | 米国 (US)                      |          |                                                                                                  |

最終頁に続く

(54) 【発明の名称】ホスト識別子を使用するプログラマブルハードウェアサブデザインのライセンス交付のための機器及び方法

## (57) 【要約】

【課題】特定のハードウェア設計に関わる複数の当事者間のライセンス交付契約の条項を実行するためのハードウェア技術を提供する。

【解決手段】ハードウェア技術の使用による特定のハードウェアデザインに関わる複数の当事者間のライセンス交付契約の条項を実行する方法及び機器。一実施形態によれば、ハードウェアサブデザインは、暗号化によってユーザによる修正から保護されたライセンス検証サブデザインを含む。一実施形態では、ライセンスは、外部ハードウェア装置内の信頼できるホスト識別子に基づいて発生される。一実施形態では、各信頼できるホスト識別子は固有であり、同じ信頼できるホスト識別子を共有する集積回路は2つとない。別の実施形態では、集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路である。一実施形態では、ライセンスは、ハードウェアサブデザインが信頼できるホスト識別子を有する集積回路内で実施された時に、ハードウェアサブデザインがどのくらい長く作動することになるかを判断する。



**【特許請求の範囲】****【請求項 1】**

暗号化されたハードウェアサブデザインを発生させる方法であって、  
第1の設計者側で第1のハードウェアサブデザインを発生させる段階と、  
第2の設計者側で第2のハードウェアサブデザインを発生させる段階と、  
信頼できるホスト識別子を有する集積回路に前記第1のハードウェアサブデザイン及び  
前記第2のハードウェアサブデザインをアップロードする段階と、  
前記信頼できるホスト識別子に基づくライセンスを適用することによって前記第2のハ  
ードウェアサブデザインを使用可能にする段階と、  
を含むことを特徴とする方法。

10

**【請求項 2】**

前記第2のハードウェアサブデザインを発生させながら該第2のハードウェアサブデザ  
イン内でライセンス検証サブデザインを暗号化する段階を更に含むことを特徴とする請求  
項1に記載の方法。

**【請求項 3】**

前記ライセンスは、信頼できるホスト識別子の群に基づいていることを特徴とする請求  
項1に記載の方法。

**【請求項 4】**

前記ライセンスは、前記第2のハードウェアサブデザインがどのくらい長く作動するこ  
とになるかを判断することを特徴とする請求項1に記載の方法。

20

**【請求項 5】**

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とす  
る請求項1に記載の方法。

**【請求項 6】**

外部ハードウェア装置が、前記信頼できるホスト識別子を提供することを特徴とする請求  
項1に記載の方法。

**【請求項 7】**

デジタル処理システム上で実行された時に、  
第1の設計者側で第1のハードウェアサブデザインを発生させる段階と、  
第2の設計者側で第2のハードウェアサブデザインを発生させる段階と、  
信頼できるホスト識別子を有する集積回路に前記第1のハードウェアサブデザイン及び  
前記第2のハードウェアサブデザインをアップロードする段階と、  
前記信頼できるホスト識別子に基づくライセンスを適用することによって前記第2のハ  
ードウェアサブデザインを使用可能にする段階と、  
を含む暗号化されたハードウェアサブデザインを発生する方法を前記デジタル処理シス  
テムに実行させる複数の実行可能な命令を収容した機械可読媒体。

30

**【請求項 8】**

前記第2のハードウェアサブデザインを発生させる段階の間に該第2のハードウェアサ  
ブデザイン内でライセンス検証サブデザインを暗号化する段階を更に含むことを特徴とす  
る請求項7に記載の機械可読媒体。

40

**【請求項 9】**

前記ライセンスは、信頼できるホスト識別子の群に基づいていることを特徴とする請求  
項7に記載の機械可読媒体。

**【請求項 10】**

前記ライセンスは、前記第2のハードウェアサブデザインがどのくらい長く作動するこ  
とになるかを判断することを特徴とする請求項7に記載の機械可読媒体。

**【請求項 11】**

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とす  
る請求項7に記載の機械可読媒体。

**【請求項 12】**

50

外部ハードウェア装置が、前記信頼できるホスト識別子を提供することを特徴とする請求項 7 に記載の機械可読媒体。

【請求項 13】

暗号化されたハードウェアサブデザインを発生させるシステムであって、  
第 1 の設計者側で第 1 のハードウェアサブデザインを発生させるための手段と、  
第 2 の設計者側で第 2 のハードウェアサブデザインを発生させるための手段と、  
信頼できるホスト識別子を有する集積回路に前記第 1 のハードウェアサブデザイン及び  
前記第 2 のハードウェアサブデザインをアップロードするための手段と、  
前記信頼できるホスト識別子に基づくライセンスを適用することによって前記第 2 のハ  
ードウェアサブデザインを使用可能にするための手段と、  
を含むことを特徴とするシステム。

10

【請求項 14】

前記第 2 のハードウェアサブデザインを発生させながら該第 2 のハードウェアサブデザ  
イン内でライセンス検証サブデザインを暗号化するための手段、  
を更に含むことを特徴とする請求項 13 に記載のシステム。

【請求項 15】

前記ライセンスは、信頼できるホスト識別子の群に基づいていることを特徴とする請求  
項 13 に記載のシステム。

【請求項 16】

前記ライセンスは、前記第 2 のハードウェアサブデザインがどのくらい長く作動するこ  
とになるかを判断することを特徴とする請求項 13 に記載のシステム。

20

【請求項 17】

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とす  
る請求項 13 に記載のシステム。

【請求項 18】

外部ハードウェア装置が、前記信頼できるホスト識別子を提供することを特徴とする請求  
項 13 に記載のシステム。

30

【請求項 19】

信頼できるホスト識別子を有する集積回路に暗号化された回路デザインをアップロードす  
る段階と、

信頼できるホスト識別子特定のライセンスに基づいて前記暗号化された回路デザインを  
使用可能にする段階と、

を含むことを特徴とする方法。

【請求項 20】

前記信頼できるホスト識別子を有する前記集積回路に、暗号化されていない回路デザイ  
ンをアップロードする段階、

を更に含むことを特徴とする請求項 19 に記載の方法。

【請求項 21】

前記信頼できるホスト識別子特定のライセンスは、信頼できるホスト識別子の群に基づ  
いていることを特徴とする請求項 19 に記載の方法。

40

【請求項 22】

前記信頼できるホスト識別子特定のライセンスは、前記暗号化された回路デザインがど  
のくらい長く作動することになるかを判断することを特徴とする請求項 19 に記載の方法  
。

【請求項 23】

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とす  
る請求項 19 に記載の方法。

【請求項 24】

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積  
回路であることを特徴とする請求項 19 に記載の方法。

50

**【請求項 2 5】**

デジタル処理システム上で実行された時に、  
暗号化された回路デザインを信頼できるホスト識別子を有する集積回路にアップロードする段階と、

信頼できるホスト識別子特定のライセンスに基づいて前記暗号化された回路デザインを使用可能にする段階と、

を含む方法を前記デジタル処理システムに実行させる複数の実行可能な命令を収容した機械可読媒体。

**【請求項 2 6】**

前記方法は、

暗号化されていない回路デザインを前記信頼できるホスト識別子を有する前記集積回路にアップロードする段階、

を更に含む、

ことを特徴とする請求項 2 5 に記載の機械可読媒体。

**【請求項 2 7】**

前記信頼できるホスト識別子特定のライセンスは、信頼できるホスト識別子の群に基づいていることを特徴とする請求項 2 5 に記載の機械可読媒体。

**【請求項 2 8】**

前記信頼できるホスト識別子特定のライセンスは、前記暗号化された回路デザインがどのくらい長く作動することになるかを判断することを特徴とする請求項 2 5 に記載の機械可読媒体。

**【請求項 2 9】**

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とする請求項 2 5 に記載の機械可読媒体。

**【請求項 3 0】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 2 5 に記載の機械可読媒体。

**【請求項 3 1】**

信頼できるホスト識別子を有する集積回路に暗号化された回路デザインをアップロードするための手段と、

信頼できるホスト識別子特定のライセンスに基づいて前記暗号化された回路デザインを使用可能にするための手段と、

を含むことを特徴とするシステム。

**【請求項 3 2】**

暗号化されていない回路デザインを前記信頼できるホスト識別子を有する前記集積回路にアップロードするための手段、

を更に含むことを特徴とする請求項 3 1 に記載のシステム。

**【請求項 3 3】**

前記信頼できるホスト識別子特定のライセンスは、信頼できるホスト識別子の群に基づいていることを特徴とする請求項 3 1 に記載のシステム。

**【請求項 3 4】**

前記信頼できるホスト識別子特定のライセンスは、前記暗号化された回路デザインがどのくらい長く作動することになるかを判断することを特徴とする請求項 3 1 に記載のシステム。

**【請求項 3 5】**

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とする請求項 3 1 に記載のシステム。

**【請求項 3 6】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 3 1 に記載のシステム。

10

20

30

40

50

**【請求項 3 7】**

信頼できるホスト識別子に基づいて集積回路内の知的財産に制約を加える方法であつて、  
信頼できるホスト識別子を有する集積回路上で特定の量の時間に對してのみ実行するこ  
とができるハードウェアサブデザインを使用可能にする該信頼できるホスト識別子特定の  
ライセンスを発生させる段階、  
を含むことを特徴とする方法。

**【請求項 3 8】**

前記信頼できるホスト識別子を有する前記集積回路に、前記ハードウェアサブデザイン  
をライセンスを必要としない別のハードウェアサブデザインと共にアップロードする段階  
10

、  
を更に含むことを特徴とする請求項 3 7 に記載の方法。

**【請求項 3 9】**

前記信頼できるホスト識別子特定のライセンスは、信頼できるホスト識別子の群に基づ  
いていることを特徴とする請求項 3 7 に記載の方法。

**【請求項 4 0】**

前記信頼できるホスト識別子特定のライセンスは、前記ハードウェアサブデザインがど  
のくらい長く作動することになるかを判断することを特徴とする請求項 3 7 に記載の方法  
。

**【請求項 4 1】**

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴と  
する請求項 3 7 に記載の方法。

**【請求項 4 2】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積  
回路であることを特徴とする請求項 3 7 に記載の方法。

**【請求項 4 3】**

デジタル処理システム上で実行された時に、

信頼できるホスト識別子を有する集積回路上で特定の量の時間に對してのみ実行するこ  
とができるハードウェアサブデザインを使用可能にする該信頼できるホスト識別子特定の  
ライセンスを発生させる段階、  
30

を含む、信頼できるホスト識別子に基づいて集積回路内の知的財産に制約を加える方法  
を前記デジタル処理システムに実行させる複数の実行可能な命令を収容した機械可読媒体  
。

**【請求項 4 4】**

前記方法は、

前記信頼できるホスト識別子を有する前記集積回路に、前記ハードウェアサブデザイン  
をライセンスを必要としない別のハードウェアサブデザインと共にアップロードする段階  
、  
40

を更に含む、

ことを特徴とする請求項 4 3 に記載の機械可読媒体。

**【請求項 4 5】**

前記信頼できるホスト識別子特定のライセンスは、信頼できるホスト識別子の群に基づ  
いていることを特徴とする請求項 4 3 に記載の機械可読媒体。

**【請求項 4 6】**

前記信頼できるホスト識別子特定のライセンスは、前記ハードウェアサブデザインがど  
のくらい長く作動することになるかを判断することを特徴とする請求項 4 3 に記載の機械  
可読媒体。

**【請求項 4 7】**

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴と  
する請求項 4 3 に記載の機械可読媒体。

10

20

30

40

50

**【請求項 4 8】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 4 3 に記載の機械可読媒体。

**【請求項 4 9】**

信頼できるホスト識別子に基づいて集積回路内の知的財産に制約を加えるシステムであつて、

信頼できるホスト識別子を有する集積回路上で特定の量の時間に対してのみ実行することができるハードウェアサブデザインを使用可能にする該信頼できるホスト識別子特定のライセンスを発生させるための手段、

を含むことを特徴とするシステム。

10

**【請求項 5 0】**

前記信頼できるホスト識別子を有する前記集積回路に、前記ハードウェアサブデザインをライセンスを必要としない別のハードウェアサブデザインと共にアップロードするための手段、

を更に含むことを特徴とする請求項 4 9 に記載のシステム。

**【請求項 5 1】**

前記信頼できるホスト識別子特定のライセンスは、信頼できるホスト識別子の群に基づいていることを特徴とする請求項 4 9 に記載のシステム。

**【請求項 5 2】**

前記信頼できるホスト識別子特定のライセンスは、前記ハードウェアサブデザインがどのくらい長く作動することになるかを判断することを特徴とする請求項 4 9 に記載のシステム。

20

**【請求項 5 3】**

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とする請求項 4 9 に記載のシステム。

**【請求項 5 4】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 4 9 に記載のシステム。

**【請求項 5 5】**

ユーザによって修正することができない信頼できるホスト識別子を有する集積回路を製造する段階、

を含むことを特徴とする方法。

30

**【請求項 5 6】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 5 5 に記載の方法。

**【請求項 5 7】**

前記集積回路は、暗号化されたライセンス検証サブデザインをハードウェアサブデザイン内に含むことを特徴とする請求項 5 5 に記載の方法。

**【請求項 5 8】**

デジタル処理システム上で実行された時に、

40

ユーザによって修正することができない信頼できるホスト識別子を有する集積回路を製造する段階、

を含む方法を前記デジタル処理システムに実行させる複数の実行可能な命令を収容した機械可読媒体。

**【請求項 5 9】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 5 8 に記載の機械可読媒体。

**【請求項 6 0】**

前記集積回路は、暗号化されたライセンス検証サブデザインをハードウェアサブデザイン内に含むことを特徴とする請求項 5 8 に記載の機械可読媒体。

50

**【請求項 6 1】**

ユーザによって修正することができない信頼できるホスト識別子を有する集積回路を製造するための手段、

を含むことを特徴とするシステム。

**【請求項 6 2】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 6 1 に記載のシステム。

**【請求項 6 3】**

前記集積回路は、暗号化されたライセンス検証サブデザインをハードウェアサブデザイン内に含むことを特徴とする請求項 6 1 に記載のシステム。

**【請求項 6 4】**

信頼できるホスト識別子を有する集積回路であって、

第 1 の設計者によって信頼できるホスト識別子とは独立に使用可能にされた第 1 のハードウェアサブデザインと、

第 2 の設計者によって前記信頼できるホスト識別子に基づいて使用可能にされた第 2 のハードウェアサブデザインと、

を含むことを特徴とする集積回路。

**【請求項 6 5】**

前記第 2 のハードウェアサブデザインは、信頼できるホスト識別子の群に基づいて使用可能にされることを特徴とする請求項 6 4 に記載の集積回路。

**【請求項 6 6】**

前記第 2 のハードウェアサブデザイン内のライセンス検証サブデザインは、修正を防止するために暗号化されることを特徴とする請求項 6 4 に記載の集積回路。

**【請求項 6 7】**

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とする請求項 6 4 に記載の集積回路。

**【請求項 6 8】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 6 4 に記載の集積回路。

**【請求項 6 9】**

信頼できるホスト識別子を有する集積回路内のロケーションであって、

集積回路内の暗号化された回路デザインを使用可能にするライセンス交付ブロックと、

前記暗号化された回路デザインがどのくらい長く作動することになるかを判断するクロック回路と、

を含むことを特徴とするロケーション。

**【請求項 7 0】**

前記ライセンス交付ブロックは、信頼できるホスト識別子の群に基づいて前記暗号化された回路デザインの少なくとも一部分を使用可能にすることを特徴とする請求項 6 9 に記載のロケーション。

**【請求項 7 1】**

前記ライセンス交付ブロックは、前記暗号化された回路がどのくらい長く作動することになるかを判断することを特徴とする請求項 6 9 に記載のロケーション。

**【請求項 7 2】**

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とする請求項 6 9 に記載のロケーション。

**【請求項 7 3】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 6 9 に記載のロケーション。

**【請求項 7 4】**

複数の集積回路 ( I C ) を設計する際に使用されるデジタル処理システムであって、

10

20

30

40

50

表示装置と、  
メモリと、

信頼できるホスト識別子を有する集積回路上でハードウェアサブデザインが特定の量の時間に対して作動することを可能にする信頼できるホスト識別子特定のライセンスを発生させる、前記メモリ及び前記表示装置に結合したプロセッサと、  
を含むことを特徴とするシステム。

【請求項 7 5】

前記プロセッサは、前記信頼できるホスト識別子を有する前記集積回路に、前記ハードウェアサブデザインをライセンスを必要としない別のハードウェアサブデザインと共にアップロードするためのものであることを特徴とする請求項 7 4 に記載のデジタル処理システム。

10

【請求項 7 6】

前記信頼できるホスト識別子特定のライセンスは、信頼できるホスト識別子の群に基づいていることを特徴とする請求項 7 4 に記載のデジタル処理システム。

【請求項 7 7】

前記信頼できるホスト識別子特定のライセンスは、前記ハードウェアサブデザインがどのくらい長く作動することになるかを判断することを特徴とする請求項 7 4 に記載のデジタル処理システム。

【請求項 7 8】

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とする請求項 7 4 に記載のデジタル処理システム。

20

【請求項 7 9】

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 7 4 に記載のデジタル処理システム。

【請求項 8 0】

設計者側の方法であって、

第 1 のハードウェアデザインと、信頼できるホスト識別子を通じて第 2 のハードウェアデザインを使用可能にする第 2 の暗号化されたデザインとを合併する段階、  
を含むことを特徴とする方法。

30

【請求項 8 1】

前記第 2 の暗号化されたデザインは、信頼できるホスト識別子の群に基づく信頼できるホスト識別子特定のライセンスを通じて使用可能にされることを特徴とする請求項 8 0 に記載の方法。

【請求項 8 2】

前記信頼できるホスト識別子特定のライセンスは、前記暗号化された回路デザインがどのくらい長く作動することになるかを判断することを特徴とする請求項 8 1 に記載の方法。

。

【請求項 8 3】

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とする請求項 8 0 に記載の方法。

40

【請求項 8 4】

前記第 1 のハードウェアデザイン及び前記第 2 の暗号化されたデザインは、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路内に組み込まれていることを特徴とする請求項 8 0 に記載の方法。

【請求項 8 5】

IP ブロック所有者側の方法であって、

別の設計者によって集積回路内に組み込むための暗号化されたデザインを発生させる段階と、

50

前記集積回路の信頼できるホスト識別子部分に対するデータを許可する段階と、  
を含むことを特徴とする方法。

**【請求項 8 6】**

前記暗号化されたデザインは、信頼できるホスト識別子の群に基づく信頼できるホスト識別子特定のライセンスを通じて使用可能にされることを特徴とする請求項 8 5 に記載の方法。

**【請求項 8 7】**

前記信頼できるホスト識別子特定のライセンスは、前記暗号化されたデザインがどのくらい長く作動することになるかを判断することを特徴とする請求項 8 6 に記載の方法。

**【請求項 8 8】**

前記集積回路は、該集積回路に対する固有の値である信頼できるホスト識別子を含むことを特徴とする請求項 8 5 に記載の方法。

**【請求項 8 9】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 8 5 に記載の方法。

**【請求項 9 0】**

信頼できるホスト識別子プロバイダ側の方法であって、  
設計者によって構成することができるプログラマブル・ゲート・アレイ又は特定用途向け集積回路を生成する段階と、  
信頼できるホスト識別子部分を前記プログラマブル・ゲート・アレイ又は前記特定用途向け集積回路に組み込む段階と、  
を含むことを特徴とする方法。

**【請求項 9 1】**

前記信頼できるホスト識別子部分は、暗号化されたライセンス検証サブデザインをハードウェアサブデザイン内に含むことを特徴とする請求項 9 0 に記載の方法。

**【請求項 9 2】**

前記信頼できるホスト識別子部分は、信頼できるホスト識別子の群に基づく信頼できるホスト識別子特定のライセンスを通じて使用可能にされることを特徴とする請求項 9 0 に記載の方法。

**【請求項 9 3】**

前記信頼できるホスト識別子特定のライセンスは、前記暗号化されたデザインがどのくらい長く作動することになるかを判断することを特徴とする請求項 9 2 に記載の方法。

**【請求項 9 4】**

前記プログラマブル・ゲート・アレイ又は前記特定用途向け集積回路は、該プログラマブル・ゲート・アレイ又は該特定用途向け集積回路に対する固有の値である信頼できるホスト識別子を含むことを特徴とする請求項 9 0 に記載の方法。

**【請求項 9 5】**

設計者側の方法であって、  
IP ブロックの暗号化された部分によって使用されて該 IP ブロックの残りの部分を使用可能にする信頼できるホスト識別子を発生させる段階、  
を含み、  
前記信頼できるホスト識別子は、集積回路をプログラムするか又は製造する時にソフトウェアによって提供される、  
ことを特徴とする方法。

**【請求項 9 6】**

前記暗号化された部分は、信頼できるホスト識別子の群に基づく信頼できるホスト識別子特定のライセンスを通じて使用可能にされることを特徴とする請求項 9 5 に記載の方法。

**【請求項 9 7】**

前記信頼できるホスト識別子特定のライセンスは、前記暗号化された回路デザインがどのくらい長く作動することになるかを判断することを特徴とする請求項 9 6 に記載の方法。

10

20

30

40

50

**【請求項 9 8】**

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とする請求項 9 5 に記載の方法。

**【請求項 9 9】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 9 5 に記載の方法。

**【請求項 1 0 0】**

IP ブロック所有者側の方法であって、

別の設計者によって集積回路内に組み込むために IP ブロックに関連した暗号化された回路デザインを発生させる段階と、

前記 IP ブロックを使用可能にするために、集積回路をプログラムするか又は製造する時にソフトウェアを通じて信頼できるホスト識別子を前記別の設計者に提供する段階と、を含むことを特徴とする方法。

**【請求項 1 0 1】**

前記暗号化された回路デザインは、信頼できるホスト識別子の群に基づく信頼できるホスト識別子特定のライセンスを通じて使用可能にされることを特徴とする請求項 1 0 0 に記載の方法。

**【請求項 1 0 2】**

前記信頼できるホスト識別子特定のライセンスは、前記暗号化された回路デザインがどのくらい長く作動することになるかを判断することを特徴とする請求項 1 0 1 に記載の方法。

**【請求項 1 0 3】**

前記信頼できるホスト識別子は、前記集積回路に対する固有の値であることを特徴とする請求項 1 0 0 に記載の方法。

**【請求項 1 0 4】**

前記集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路であることを特徴とする請求項 1 0 0 に記載の方法。

**【発明の詳細な説明】****【技術分野】****【0 0 0 1】**

本発明は、一般的に、集積回路の設計の分野に関するものであり、より具体的には、特定のハードウェア設計に関わる複数の当事者間のライセンス交付契約の条項を実行するためのハードウェア技術に関する。

**【背景技術】****【0 0 0 2】**

複合ハードウェアシステムの設計は、ゼロからの新しいハードウェアサブデザインの作成（例えば、専有ハードウェアデザインコード及びサポート文書の各部分）及び IP ブロック所有者によって準備されたハードウェアサブデザインの購入の組合せを伴っている。多くの場合、設計者は、社内的に特定のハードウェアサブデザインを開発するのではなく、ハードウェアサブデザインを IP ブロック所有者（例えば、ハードウェアサブデザインに対して知的財産権を有する組織 / 個人）から購入する。IP ブロック所有者は、彼の知的財産権のライセンス交付及び管理維持においていくつかの問題に直面している。最大の問題の 1 つは、使用毎ベースのハードウェアサブデザインの無断使用及びそれをライセンス交付する有効な方法の欠如である。残念ながら、FPGA（フィールド・プログラマブル・ゲート・アレイ）及び ASIC（特定用途向け集積回路）には、信頼されかつ固定した固有の識別子はなく、その結果、使用毎のベースでハードウェアサブデザインをライセンス交付することが容易にはできない（例えば、使用毎のライセンスには、特定のハードウェアサブデザインが実施されている全ての装置の課金が必要になり、信頼される固有の識別子がないために、特定のライセンスを特定の FPGA に固定することが困難になると考えられる）。代わりに、IP ブロック所有者は、多くの場合に、設計者がハードウェア

サブデザインの各使用に対して適正に計上してその支払いを行うと信頼しない限り（例えば、長期的に続くビジネス関係を通して）、グローバルな1回限りのライセンス（例えば、設計者側のいずれか及び全てのFPGA上で特定のハードウェアサブデザインを使用するグローバルな1回限りのライセンス）を販売する必要がある。更に、ハードウェアサブデザインがどこでコピーされて適用されているかを追跡する方法がないために、業界内に窃盗が広がり蔓延している（例えば、ハードウェアサブデザインが販売された状態で、IPプロック所有者は、特定のハードウェアサブデザインがFPGA上で何回検索されたかをモニタかつ判断することができない）。従って、IPプロック所有者は、ハードウェアサブデザインにおいて知的財産権を最大限利用することができず、かつ彼らのハードウェアサブデザインが最終的にどこで利用されているのかを管理することができない。

10

## 【0003】

図1Aは、複数のIPプロック110A～110Iを有するFPGA118を示している。FPGA118は、バス108を通じて設計者111と結合される。設計者111（例えば、ハードウェアシステムを作成している個人又は会社）は、ハードウェアサブデザインをバス108を通じてFPGA118に転送する（例えば、設計者111は、設計者111が以前作成した特定のハードウェアサブデザインを再利用することができ、特注デザインを開発することができ、パブリックドメインのデザインを使用することができ、又は第三者IPプロック所有者から購入したか又はそれによって作成されたデザインを使用することができる）（例えば、設計者111は、デザインの表示をFPGA118に転送し、1つ又はそれよりも多くのIPプロック110A～110I及び/又は設計者の論理150をプログラムすることができる）。

20

## 【0004】

FPGA118は、設計者の論理150と複数のIPプロック110A～110Iを含む。設計者の論理150は、設計者111が既に作成したハードウェアサブデザインを含む。FPGA118内の各IPプロック110A～110Iは、第三者から購入したハードウェアサブデザインを含む（例えば、特定のIPプロック110A内のハードウェアサブデザインは、例えば、図1Bに示すように第三者IPプロック所有者100から購入することができる）。

30

## 【0005】

図1Bは、デザインを実施するための設計者111と、IPプロック所有者100と、FPGAプロバイダ120との間の従来技術のトランザクション流れ図を示している。図1Bにおいて、設計者111は、最初に、丸で囲んだ1に示すようにFPGAプロバイダ120と通信する。丸で囲んだ1の通信は、FPGA装置118をFPGAプロバイダ120から購入する要求とすることができます（例えば、FPGAプロバイダは、代理店、小売業者、製造業者、及び/又は卸売業者のようなあらゆる商業レベルのFPGA納入業者とすることができます）。次に、FPGAプロバイダ120は、丸で囲んだ2でFPGA118を設計者111に出荷する（例えば、FPGAプロバイダ120は、信用調査を行い、送り状を作成し、設計者111とFPGAプロバイダ120間の商取引の一部としてオファーを受諾することができます）。

40

## 【0006】

設計者111が、丸で囲んだ2で、FPGA118をFPGAプロバイダ120から受領した後に、設計者111は、丸で囲んだ3で、設計者111が彼のハードウェアシステムを完了するために必要とする専有ハードウェアサブデザインを購入する要求をIPプロック所有者100に送る（例えば、IPプロック所有者100は、設計者111が彼に与えられた時間及び経費上の制約の範囲内で彼のハードウェアシステムを完了するために必要とする専有ハードウェアサブデザインの所有権を有する場合がある）。設計者111が、丸で囲んだ3で、要求をIPプロック所有者100に提供した後に（例えば、設計者111は、発注書の形で専有ハードウェアサブデザインを購入するオファーをIPプロック所有者100に電子メールで送ることができ、又はIPプロック所有者100に電話して専有ハードウェアサブデザインを購入することができる）、IPプロック所有者100は

50

、丸で囲んだ 4 で、専有ハードウェアサブデザインを設計者 111 に供給する（例えば、IP ブロック所有者 100 は、グローバルライセンスに関する契約を締結して、IP ブロック所有者 100 が有する専有ハードウェアサブデザインのグローバル知的財産ライセンスを購入する設計者 111 のオファーを受諾した後に、HDL 及び / 又は RTL 実施デザイン詳細及び専有ハードウェアサブデザインの実施に必要な対応する文書を設計者 111 に提供することができる）。

#### 【0007】

次に、設計者 111 は、IP ブロック所有者 100 から受領した専有ハードウェアサブデザインを FPGA 装置 118 に組み込む（例えば、設計者 111 は、図 1A で上述したように、バス 108 を通じて FPGA プロバイダ 120 から設計者 111 が購入した FPGA 118 をプログラムすることができる）。残念ながら、IP ブロック所有者 100 は、専有ハードウェアサブデザインの詳細が設計者 111 に送られた後は、彼の知的財産を管理することができなくなる。IP ブロック所有者 100 が彼らの専有ハードウェアサブデザインの一部を暗号化したとしても、設計者 111 は、彼 / 彼女が所望する多くの FPGA 118 にそれを自由に複製して利用することができる（例えば、暗号化された回路の他に、ライセンスコードを複製することにより）。更に、IP ブロック所有者 100 は、設計者 111 が IP ブロック所有者 100 の提供した専有ハードウェアサブデザインを悪用したか否かを判断することができない上に、設計者 111 が専有ハードウェアサブデザインを他人に再販したか否かをモニタすることができない（例えば、IP ブロック所有者 100 は、彼の専有ハードウェアサブデザインの最初の設計に何百万ドルも投資したかもしれない、かつ IP ブロック所有者 100 は、彼の知的財産を他人にライセンス交付することができないので、設計者 111 による専有ハードウェアサブデザインの悪用及び / 又は窃盗に対する以外は、投資額を取り戻すのは困難であろう）。従って、IP ブロック所有者によって作成された専有ハードウェアサブデザインを保護するための改良型の機器及び方法を提供することが望ましいことが分る。

#### 【発明の開示】

#### 【0008】

本発明は、ハードウェア技術の使用による特定のハードウェアデザインに関わる複数の当事者間のライセンス交付契約の条項を実行する方法及び機器を開示する。本発明の 1 つの態様によれば、ハードウェアサブデザインは、暗号化によってユーザによる修正から保護されたライセンス検証サブデザインを含む。1 つの態様では、ライセンス交付検証サブデザインと、IP ブロックを使用不可にするハードウェアサブデザイン内の論理コードの一部との接続も、修正を防止するために暗号化される。1 つの態様では、ライセンスは、外部ハードウェア装置内の信頼できるホスト識別子に基づいて発生される。別の態様では、ユーザは、信頼できるホスト識別子を修正することはできない。本発明の 1 つの態様では、各信頼できるホスト識別子は固有であり、同じ信頼できるホスト識別子を共有する集積回路は 2 つとない。本発明の別の態様では、集積回路は、フィールド・プログラマブル・ゲート・アレイ又は特定用途向け集積回路である。

#### 【0009】

本発明の別の態様によれば、例示的な方法は、設計者によって設計された第 1 のハードウェアサブデザインを信頼できるホスト識別子を有するプログラマブル・ゲート・アレイ上にアップロードし、並びに第三者によって提供され、かつ特定の信頼できるホスト識別子を有するプログラマブル・ゲート・アレイ上でのみ機能することができる第 2 のハードウェアサブデザインをアップロードする。本発明の別の態様では、ライセンスは、信頼できるホスト識別子の群に基づいて発生される。1 つの態様では、ライセンスは、ハードウェアサブデザインが信頼できるホスト識別子を有する集積回路内で実施された時に、ハードウェアサブデザインがどのくらい長く作動することになるかを判断する。本発明はまた、集積回路の設計に使用することができるソフトウェア媒体を含む機器を開示する。例えば、本発明は、本発明により集積回路を設計することができるデジタル処理システムを含み、本発明はまた、コンピュータシステムのようなデジタル処理システム上で実行された

10

20

30

40

50

時にデジタル処理システムに集積回路を設計する方法を実行させる機械可読媒体を提供する。

【0010】

本発明の他の特徴は、添付の図面及び以下の詳細説明から明らかになるであろう。

【0011】

本発明は、一例として示すものであり、同じ参照番号が類似の要素を示す添付図面の図に制限するものではない。

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

【0012】

特定のハードウェアデザインに関わる複数の当事者間のライセンス交付契約の条項を実行するのに使用されるハードウェア技術の方法及び機器を本明細書で説明する。以下の説明においては、説明を目的として、本発明を完全に理解することができるよう多くの特定の詳細事項に対して説明する。しかし、これらの特定の詳細事項がなくても本発明を実施することができることは、当業者には明らかであろう。他の事例においては、公知の構造、処理、及び装置をブロック図の形で示し、又は必要以上の詳細事項なく説明を行うために要約して参照する。本発明の方法の多くは、従来の汎用コンピュータシステムのようなデジタル処理システムと共に実施することができる。

10

【0013】

図2Aは、本発明の一例示的実施形態による信頼できるホスト識別子245と、複数のライセンス交付ブロック205A～205Iと、各ライセンス交付ブロック205A～205Iに関連した複数のIPブロック210A～210Iとを有するFPGA218を示している。設計者211は、バス208を通じてFPGA218と通信する（例えば、設計者211は、バス208を通じてFPGAにダウンロードする前にビットストリームを合成、配置、経路指定、及び発生させることにより、ハードウェアサブデザインの全ての部分を編集することができる）。設計者211は、一実施形態によると、社内で作成されたハードウェアサブデザイン並びに第三者から購入したハードウェアサブデザインを使用するハードウェアシステム設計者とすることができます（例えば、設計者211は、特定のハードウェアサブデザインをIPブロック所有者200から購入して、設計者の論理250と組み合わせてバス208を通じてFPGA218内で完全なデザインを作ることができます）。バス208は、直接接続ローカルバス（例えば、シリアル及び/又はパラレルポートを通じてFPGAに直接に接続したコンピュータ）とすることができます。代替的に、バス208は、別の実施形態によると、設計者211がFPGA218と通信するローカル又はワイドエリアネットワークとすることができます。

20

30

40

【0014】

FPGA218は、設計者の論理250と、信頼できるホストID245と、1つ又はそれよりも多くのIPロケーション240A～240Iとを含む。設計者の論理250は、設計者211によって単独に作成されたハードウェアサブデザインを含む（例えば、設計者の論理250は、検証された上に既に試験済みであるハードウェアサブデザインを含むこともあります、また、他のデザインにおいて過去に使用されたハードウェアサブデザインを含む場合がある）。設計者の論理250は、IPロケーション240A～240Iからに分離され、これは、IPロケーション240A～240Iが一実施形態では第三者によって設計されたハードウェアサブデザインのために使用される場合があるからである。

【0015】

FPGA218内の信頼できるホストID245（信頼できるホスト識別子）は、FPGA218に対する固有の信頼できるホスト識別子を維持する。信頼できるホストID245の実施は、一実施形態では、内蔵連続番号（例えば、FPGAは、内蔵連続番号として製造することができる、又は内蔵連続番号は、1回限りのプログラマブル連続番号とすることができます）及びライセンス検証サブデザインにおいて使用することができる設計構成要素（例えば、ハードウェアサブデザイン内のライセンス検証サブデザイン）を用いて、ユーザが目視可能な接続部なしにその連続番号にアクセスすることで（例えば、ユーザ

50

による修正からサブデザインのライセンス検証部分を保護する)、フィールド・プログラマブル・ゲート・アレイ内で行うことができる。信頼できるホストID245は、一実施形態では、FPGA218に永久的に関連付けられた固有番号とすることができます(例えば、信頼できるホストIDは、製造中にFPGA製造業者のような信頼できるホストIDプロバイダによって予め設定された番号とすることができます)。一実施形態では、信頼できるホストID245の一部は、図2Bに示すように、信頼できるホストIDプロバイダ220によって設計者211に販売されたFPGAの群に関して共通とすることができます(例えば、固定の上位の組のビットを有するマスキングと信頼できるホストIDとを組み合わせることができる)(例えば、FPGA218の製造時期及び/又は製造場所を示すように、信頼できるホストIDプロバイダ220が設計者211に数値ホストIDの一部を販売したFPGAの特定のバッチと関連付けることができる)。信頼できるホストID245のアイデンティティは、一実施形態では、FPGA218に問合わせすることでバス208を通じて設計者211が検索することができます(例えば、設計者211が有するソフトウェアプログラム又はソフトウェアプログラムは、設計者211が信頼できるホストID245のコンテンツを読むことを可能にすることができます)。信頼できるホストID245は、FPGA218を完全に使用不可にすることなしに変えることはできないことに注意すべきである(例えば、誰かが信頼できるホストID245のアイデンティティを変えようとした場合、FPGA218を使用不可にする回路遮断器を通じた改ざんに対して信頼できるホストID245を保護することができます)。一実施形態では、信頼できるホストID245は、フィールド・プログラマブル・ゲート・アレイの外部にあり、セキュアではないチャンネル(例えば、仮想専用ネットワークプロトコル)によるセキュアな通信に様々な公知の方法を使用することができます。

10

20

30

40

#### 【0016】

一実施形態では、設計者211は、FPGA218にダウンロードする前にビットストリームを合成、配置、経路指定、及び発生させることで、ハードウェアサブデザインの全ての部分を編集することができます。代替的に、部分的再構成を目的とした別の実施形態では、各IPブロック205A～205IをFPGA218上の異なるロケーションに個別にダウンロードすることができます。各IPロケーション240A～240Iは、ライセンス交付ブロック205A～205IとIPハードウェアサブデザインブロック210A～210I(例えば、又はIPブロック210A～210I)とを含む。各IPロケーション240A～240Iを設計者の論理250に接続することができます(例えば、特定のIPロケーション240Aが設計者の論理250と通信してハードウェアサブデザイン命令を共有することを可能にするために)。一実施形態では、新しいハードウェアサブデザインが追加及び/又はIPブロック210A～210Iの範囲内から削除された時、IPロケーション240A～240Iを使用可能及び使用不可にすることができます(例えば、IPロケーション240Aは、物理的IPロケーションに対して、図2Bに示すようにIPブロック所有者から購入された専有ハードウェアサブデザインがFPGA218内で追加及び/又は削除された時に作成されるIPブロック210Aに対して、特定のライセンス交付ブロック205Aの論理的関連付けとすることができます)。一実施形態では、ライセンス交付ブロック205A～205Iを使用して、IPブロック210A～210Iを使用可能にすることができます(例えば、特定のライセンス交付ブロック205Aは、図2Bの丸で囲んだ4で示すように、IPブロック210Aのコンテンツをアンロックして、IPブロック所有者200によって提供されるハードウェアサブデザインを明らかにすることができます)。

50

#### 【0017】

ライセンス交付ブロック205Aは、ライセンスを受信し、信頼できるホスト識別子245を分析してIPブロックのどの特徴を使用可能にすべきであるかを判断することができます。一実施形態では、ライセンス交付ブロック205A～205Iは、ハードウェアサブデザインの作動を使用可能にするために信頼できるホストID245と共に(図2Bに示すように)IPブロック所有者200から受信したライセンスコードの整合性を検証す

るライセンス検証ハードウェア（例えば、ハードウェアサブデザインを発生させる間に暗号化されるハードウェアサブデザイン内のライセンス検証サブデザイン）を含む。従って、ライセンス交付プロック 205A～205I は、IP ブロック所有者（図 2B に示すような IP ブロック所有者 200 など）から受信したライセンスコードを信頼できるホスト ID 245 に依存するライセンス交付プロック 205A～205I 内の内部暗号化手法と比較することで、知的財産を有するライセンス交付されていない設計者が IP ブロック 210A～210I 内のハードウェアサブデザインにアクセスするのを防止する電子ロックとして作動することができる（例えば、一実施形態では、ライセンスコードは、信頼できるホスト ID 245 を有する FPGA 上でしか機能することはできない）。一実施形態では、ライセンス交付プロック 205A は、（図 2B で丸で囲んだ 4 で示すように）IP ブロック所有者 200 からライセンスコードを受信した設計者 211 から、バス 208 を通じてそのライセンスコード（例えば、バイナリデータのストリング）を受信することができる。別の実施形態では、ライセンス交付プロック 205A は、ライセンスコードを信頼できるホスト ID 245 及びライセンス交付プロック 205A 内の暗号化手法と比較することができる。一実施形態では、ライセンスコードは、IP ブロック 210A～210I 内に組み込むことができ、及び／又は設計者の論理 250 内に組み込むことができる。

#### 【0018】

IP ブロック 210A～210I は、一実施形態によれば、第三者 IP ブロック所有者によって提供されたハードウェアサブデザインとすることができます（例えば、図 2B で後述するような IP ブロック所有者 200）。別の実施形態では、異なる IP ブロック所有者が、IP ブロック 210A～210I を形成するように設計者 211 に自社のハードウェアサブデザインを販売又はライセンス交付していたかもしれない（例えば、第 1 の IP ブロック所有者が、ハードウェアサブデザインを IP ブロック 210A 内に供給する場合があり、一方、異なる IP ブロック所有者が、ハードウェアサブデザインを IP ブロック 210B 内に供給する場合もある）。IP ブロック 210A～210I のうちの複数の IP ブロックは、別の実施形態では、共通のライセンス交付プロック 205A～205I を共有することができ、及び／又は共通のライセンスコードがコンテンツを使用可能にすることを可能にすることができます（例えば、同じライセンスコードは、ライセンス交付プロック 205A 並びにライセンス交付プロック 205B をアンロックするように作動することができる）。ライセンス交付プロック 205A～205I は、修正を防止するために暗号化されたライセンス検証サブデザインを含むことができる。一実施形態では、IP ブロック 210A～210I は、特定の信頼できるホスト ID 245 値を有する FPGA 218 上でしか機能することはできず、異なるホスト ID 値を有する異なる FPGA 上では機能しない。ライセンス交付プロック 205A～205I は、一実施形態では、IP ブロック所有者 200 によって提供された信頼できるホスト ID 245 及びライセンスの組合せに基づいて作動の意思決定を行うことができる。ライセンスが有効でなく、かつ検証が失敗した場合、一実施形態では、ハードウェアサブデザインの論理を妨害する（状態機械をリセットさせ、かつメモリを決して書き込みさせない）信号をアサートすることで、ハードウェアサブデザインの作動を防止することができる。ライセンス検証サブデザインを暗号化して、ユーザがライセンス検証サブデザインのいずれの部分も修正することができないようにすることができます（例えば、このデザインツールフローは、ハードウェアサブデザインのこの部分の編集を防止することができます）。一実施形態では、ハードウェアサブデザインの暗号化は、ハードウェアサブデザイン内のライセンス検証サブデザインを修正から保護する目的だけに行われる。一実施形態では、ライセンス検証サブデザインと、IP ブロックを使用不可にするハードウェアサブデザイン内の論理コードの部分との接続を暗号化して修正を防止することができる。

#### 【0019】

図 2B は、本発明の一例示的実施形態による信頼できるホスト ID 245 とライセンスコードとを用いたハードウェアデザインの実施に関する設計者 211 と、IP ブロック所有者 200 と、信頼できるホスト ID プロバイダ 220 との間のトランザクション流れ図

10

20

30

40

50

を示している。図2Bにおいては、設計者211は、ホストID付きFPGA218を購入する要求を信頼できるホストIDプロバイダ220に送る。一実施形態では、信頼できるホストIDプロバイダ220は、IPプロック所有者200が、信頼される製造業者によって製造された各FPGAが固有かつ編集不能なホストID218を有すると信じるよう、十分な信頼に足る企業の評判を築いてきたFPGA製造業者のような信頼される製造業者とすることができます。

#### 【0020】

代替的に、別の実施形態では、信頼できるホストIDプロバイダ220は、コンピュータ（例えば、図3のコンピュータ311など）に接続した時に信頼できるホスト識別子を供給する外部ハードウェア装置（例えば、ドングル及び／又はマイクロチップ）を製造する企業とすることができます。丸で囲んだ1では、設計者211は、信頼できるホストID（又は信頼できるホスト識別子を有するFPGA218）を信頼できるホストIDプロバイダ220に注文する（例えば、設計者211は、特注集積回路の設計で使用される内蔵の信頼できるホストID245を有するFPGA218の購入の注文書を信頼できるホストIDプロバイダ220に送ることで注文することができる）。また、設計者211は、丸で囲んだ1で、信頼できるホストIDプロバイダ220に、設計者211がどのIPプロック所有者200のハードウェアサブデザインをハードウェアシステムで使用するつもりであるかを連絡することができる（例えば、設計者211は、例えば、IPプロック所有者200が作成したハードウェアサブデザインを使用するつもりであることを信頼できるホストIDプロバイダに連絡することができる）。

10

20

30

40

#### 【0021】

丸で囲んだ2で、信頼できるホストIDプロバイダ220は、FPGA218を有するFPGAを設計者211に出荷するか、又は信頼できるホスト識別子を有する外部ハードウェア装置を供給する（例えば、信頼できるホストIDプロバイダ220は、設計者211と拘束力のある契約を締結して、例えば、設計者211が注文した各FPGA218に対して固有のホストIDを発生させることができる）。一実施形態では、外部ハードウェア装置を直接にFPGAに接続することができるので、外部ハードウェア装置をコンピュータに接続するという点が不要になると考えられる。一例示的実施形態では、信頼できるホストIDプロバイダ220が外部ハードウェア装置を供給した場合、設計者211は、IPプロック所有者200が所有するハードウェアサブデザインが使用されるASIC及び／又はFPGAに接続したコンピュータに外部ハードウェア装置を接続する必要があると考えられる（例えば、設計者211は、IPプロック所有者200が所有するハードウェアサブデザインを使用するASIC及び／又はFPGAへの書込みに設計者211が使用することができるコンピュータ上のUSBポートに信頼できるホスト識別子を有する周辺装置を接続するであろう）。代替的に、一実施形態では、コンピュータの製造番号をホスト識別子として用いることができる。IPプロック所有者200は、外部ハードウェア装置によって発生されたホスト識別子が固有かつ修正不可能であると確信すべきである（例えば、信じる）ことに注意すべきである。従って、IPプロック所有者200は、一実施形態では、信頼できるホスト識別子を発生させたいと考えている各信頼できるホストIDプロバイダ220を事前に資格審査する必要があると考えられる。別の実施形態では、独立した業界団体が、信頼できるホストIDプロバイダの指針及び資格を提供することができる。

#### 【0022】

次に、丸で囲んだ3では、設計者211は、IPプロック所有者200に、設計者211がホストID付きFPGA218（又は、信頼できるホスト識別子を有する外部装置）を購入したことを知らせ、設計者211は、IPプロック所有者200が所有するハードウェアサブデザインを発注する（例えば、設計者211は、複合集積回路の一部をIPプロック所有者200から購入して、例えば、設計者211がゼロから設計するのではなく時間を節約することができるようになることができる）。また、設計者211は、IPプロック所有者200に信頼できるホストIDを知らせることができる（例えば、設計者2

50

11は、ホストIDを有するFPGA218及び/又は外部ハードウェア装置内で固定レジスタを読み取ることで、信頼できるホスト識別子のIDを判断するソフトウェアプログラムを実施することができる)。

#### 【0023】

次に、IPロック所有者200は、丸で囲んだ3で、設計者211から受信する信頼できるホストID情報を組み合わせて、設計者211が購入したいと考えているハードウェアサブデザイン向けにカスタマイズされている設計者211のための信頼できるホスト識別子特定のライセンスを発生させる(例えば、IPロック所有者200は、図2Aに示すように、信頼できるホストID245を使用してハードウェアサブデザイン内のライセンス検証サブデザインを暗号化し、特定のホスト識別子218のみを使用してIPロック所有者200が供給したハードウェアサブデザイン内の1つ又はそれよりも多くの特徴を検証して使用可能にすることを要件とするライセンスコードを発生させることができる)。一実施形態では、ライセンス検証サブデザインは、IPロック所有者200によって提供された信頼できるホストID245とライセンスの組合せに基づいて、作動の意思決定を行うことができる。ライセンスが有効でなく、かつ検証が失敗した場合、一実施形態では、ハードウェアサブデザインの論理を妨害する信号をアサートすることで、ハードウェアサブデザインの作動を防止することができる。

10

#### 【0024】

次に、丸で囲んだ4では、IPロック所有者200は、固有のホストIDを有する特定のFPGA218向けにカスタマイズされているライセンスコード(例えば、IPロック所有者200が所有するハードウェアサブデザイン内の1つ又はそれよりも多くの特徴をアンロックするライセンスコード)と共にハードウェアサブデザイン(例えば、IPロック所有者200が所有するハードウェアサブデザイン)を設計者211に供給する。一実施形態では、IPロック所有者200は、修正を防止するために暗号化されているハードウェアサブデザイン内にライセンス検証サブデザインを発生させる。一実施形態では、ライセンスは、設計者211がIPロック所有者200の有するハードウェアサブデザインを使用したいと考えている様々なFPGAのための信頼できるホストIDの群に関して発生される(例えば、IPロック所有者200は、各々が固有のホストIDを有するFPGAの群上にIPロック所有者200が所有するハードウェアサブデザインを設置するための注文を設計者211から受注することができ、IPロック所有者200は、ハードウェアサブデザインの使用を設計者211が購入した全ての資格審査用ホストIDに許可することができる)。

20

#### 【0025】

信頼できるホストID245を有するFPGA上でのみ機能することができるライセンスを供給することで、IPロック所有者200は、IPロック所有者200が所有するハードウェアサブデザインが使用される方法をより有効に規制することができる(例えば、IPロック所有者200は、信頼できるホストIDの特定の群のみで作業するライセンスを設計者211に供給することで、ハードウェアサブデザインの使用を特定のFPGAにのみ制限することができる)。代替的に、IPロック所有者200は、一実施形態では、信頼できるホスト識別子を含む外部ハードウェア装置が設計者211側のコンピュータに接続されることを要件とするライセンスコードを供給することができる。例えば、IPロック所有者200のハードウェアサブデザインは、外部ハードウェア装置が接続されているASIC及び/又はFPGA上でしか作動することはできない。従って、IPロック所有者200は、グローバルライセンスに対してではなく使用毎のベースで課金することで、知的財産(例えば、ハードウェアサブデザイン)に対して可変の金額を課金することができる(例えば、IPロック所有者200は、全てのFPGAを対象としてハードウェアサブデザインをライセンス交付する1回限りの料金とは対照的に、ハードウェアサブデザインの全てのインスタンスが既知であるという点で実施機構が存在するので、ハードウェアサブデザインが使用される各FPGAに対して課金することができる)。更に、IPロック所有者200が所有するハードウェアサブデザインを信頼できるホ

30

40

50

スト識別子を有するライセンシーだけに制限することで、IP ブロック所有者 200 は、IP ブロック所有者 200 が所有するハードウェアサブデザインの無許可サブライセンス交付及び／又は盜難を防止することができる。従って、設計者 211 は、IP ブロック所有者 200 から事前の許可を得なければ、IP ブロック所有者 200 からライセンス交付されたハードウェアサブデザインの無許可の複写を発生させることはできない。設計者 211 は、設計者 211 が IP ブロック所有者 200 から受信するハードウェアサブデザインが、特定の信頼できるホスト識別子を用いてのみ機能することになるので、設計者 211 が更に別のコピーを使用することを明示的に許可するライセンスを購入すべきである（例えば、IP ブロック所有者 200 は、IP ブロック所有者 200 が付与するライセンスを特定の信頼できるホスト ID を有する FPGA だけに制限することができる、IP ブロック所有者 200 が所有するハードウェアサブデザインの拡散を防止することができる）。

10

#### 【0026】

図 3 は、本発明の一例示的実施形態によるデザイン実施に関するコンピュータと、ライセンス発生器と、信頼できるホスト ID プロバイダとの間の信頼できるホスト識別子及びライセンスコードの使用のハードウェア図を示している。図 3 は、図 3 が図 2B に示す当事者によって使用される特定のハードウェアを示す点を除き、図 2B で発生させる全ての処理が図 3 に発生させるという点において図 2B と類似のものである。コンピュータ 311 は、図 2B で上述のように、設計者 211 内にある（コンピュータ 311 は、図 2A に示すように、バス 208 を通じてホスト ID 218 を有する FPGA と通信することができる）。コンピュータ 311 は、丸で囲んだ 1 及び丸で囲んだ 2 に示しかつ図 2B で上述のように、通信で信頼できるホスト ID プロバイダ 220 から信頼できるホスト ID 245 を受信する（例えば、FPGA 218 は、当事者が契約を締結した後で、図 2B に示すように、コンピュータ 311 で使用されるように、信頼できるホスト ID プロバイダ 220 が設計者 211 に出荷することができる）。次に、IP ブロック所有者 200 内のライセンス発生器 300 は、丸で囲んだ 3 及び丸で囲んだ 4 で、信頼できるホスト ID 245 専用のライセンスを発生させる（例えば、ライセンス発生器 300 は、ハードウェアサブデザインがアンロックされるように特定の信頼できるホスト ID 245 に依存するライセンスを発生させることができる）。一実施形態では、ライセンス発生器 300 は、ハードウェアサブデザイン内の暗号化ライセンス検証サブデザインと、特定の FPGA 218 内の信頼できるホスト ID 245 に依存するカスタマイズホスト ID 専用ライセンスコードとを発生させるために IP ブロック所有者 200 が使用するアプリケーションプログラムである。丸で囲んだ 4 では、信頼できるホスト ID 専用ライセンスコード並びにハードウェアサブデザインをライセンス発生器 300 からコンピュータ 311（図 2B に説明するような設計者 211 側のコンピュータ 311）に供給する。

20

#### 【0027】

図 4A は、本発明の実施形態の実施に使用することができるコンピュータシステム 311 のブロック図である。コンピュータシステム 311 は、HDL コードに説明されているデザインの論理合成に使用する。コンピュータシステム 311 は、バス 401 を通じてランダムアクセスメモリ 404 と、読み出し専用メモリ 406 と、大容量記憶装置 407 とに結合されたプロセッサ 402 を含む。大容量記憶装置 407 は、フロッピー（登録商標）ディスクドライブ、固定ディスクドライブ（例えば、磁気ドライブ、光ドライブなど）のような持続性データ記憶装置を表している。プロセッサ 402 は、汎用プロセッサ（「Intel Pentium（登録商標）」プロセッサのような）、専用プロセッサ、及び／又は特殊プログラム論理デバイスにおいて実施することができる。ディスプレイ 420 は、バス 401 を通じてプロセッサ 402 に結合され、コンピュータシステムにグラフィック出力を供給する。このグラフィック出力は、一般的に、コンピュータシステムの作動の制御に使用することができるグラフィカルユーザインターフェースである。キーボード 421 及びカーソル制御装置 422 は、情報及び指令選択をプロセッサ 402 に通信するためにバス 401 に結合される。カーソル制御装置 422 は、一般的に、表示装置 420

30

40

50

上に表示されるカーソルの制御に使用することができるマウス又は他のカーソル制御装置であることになる。また、プロセッサ 402 には、データの制御及びコンピュータシステム 311 に結合されるプリンタ及び他のコンピュータのような電気装置へ及びそれからの転送に使用することができる入力 / 出力インターフェース 423 がバス 401 を通じて結合される。また、信頼できるホスト I D 245 をコンピュータシステム 311 に結合することができる。一実施形態では、信頼できるホスト I D 245 は、外部ハードウェア装置である。別の実施形態では、信頼できるホスト識別子は、信頼できるホスト I D 245 を有する F P G A 218 内にある。また、信頼できるホスト I D 245 は、直接にコンピュータシステム 311 ではなく、特定の入力 / 出力インターフェース 423 に結合することができる。

10

#### 【 0028 】

図 4 のアーキテクチャは、説明のみを目的として提供するものであり、本発明に関連して使用されるコンピュータシステム又は他のデジタル処理システムは、この特定のアーキテクチャに限定されるものではないことに注意すべきである。

#### 【 0029 】

ここで、図 4 B を参照して本発明のある一定の実施形態の一般的な例を説明する。図 4 B は、本発明の一例示的実施形態により信頼できるホスト I D 245 を有する F P G A 218 内のハードウェアサブデザインの実施に使用される設計者 211 側のコンピュータシステム 311 内での作動を示す流れ図である。本発明の大部分の実施形態は、H D L デザイン合成ソフトウェアでの使用を意図したものであるが、本発明は、必ずしもこのような使用に限定されるものではない。一実施形態では、ハードウェアサブデザインは、実際には、暗号化によって隠されたこのような部分を有する簡単なネットリストとして簡単に表すことができることに注意すべきである。ハードウェアサブデザインは、H D L 又は動作記述でなくてもよい。コンピュータプログラムにおける他の言語の使用が可能であるが、本発明の実施形態は、H D L 合成システム、特に、販売業者特異の技術 / アーキテクチャを有する集積回路と共に使用するために設計された H D L 合成システムにおける使用という関連で以下に説明する。

20

#### 【 0030 】

公知の通り、プログラマブル I C の納入業者は、一般的に目標のアーキテクチャを判断する。目標アーキテクチャの例は、カリフォルニア州サンホセ所在の「 X i l i n x 、 I n c . 」製フィールド・プログラマブル・ゲート・アレイのプログラム済みルックアップテーブル ( L U T ) 及び関連論理である。目標アーキテクチャ / 技術の他の例としては、 A l t e r a 、「 L u c e n t T e c h n o l o g i e s 」、「 A d v a n c e d M i c r o D e v i c e s 」、及び「 L a t t i c e S e m i c o n d u c t o r 」のような販売業者製の F P G A 及び複合プログラマブル論理デバイスにおける公知のアーキテクチャがある。また、ある一定の実施形態に対しては、本発明は、 A S I C と共に採用することもできる。

30

#### 【 0031 】

図 4 B の方法は、設計者 ( 図 2 B に示すような設計者 211 など ) が、修正から保護されたライセンス検証ハードウェアを含む設計図 ( 例えば、望ましい回路の動作記述 ) を作成する作業 411 で始まる。作業 412 においては、隠されている I P ブロックと共にデザインを表示し、編集不能な I P ブロックを除くデザインに対する変更を可能にする ( 例えば、設計者の論理 250 は、編集可能であるが、 I P ブロック所有者 200 によって提供されたハードウェアサブデザイン I P ロケーション 240 A ~ 240 I は、隠すことができ、図 2 A に示すように、部分的又は完全であるかを問わず、編集不能にすることができる ) 。次に、作業 413 において、H D L コンパイラで設計図をコンパイルして、技術に無関係の R T L ネットリストを発生させる。このネットリストは、特定の販売業者の技術から独立したものであり、これは、特定の目標アーキテクチャによって使用される構築用ブロック ( 例えば、ルックアップテーブル、マルチプレクサ、及び A N D / O R アレイなど ) のライブラリから独立したものであることを意味する。設計図の少なくとも一部は

40

50

、暗号化済みであるために修正に対してセキュアである。

【0032】

作業414においては、設計図を最適化する（例えば、論理を最適化して論理のタイミングパラメータを改善する）。この作業は、任意的であり、これを使用して最適化ルーチンに従って二重の相互接続及び論理デバイスを除去する。次に、作業415においては、従来の配置及び経路指定ソフトウェアツールを使用して、Xilinx又はAlteraのFPGAのような目標アーキテクチャにおける回路のデザインを作成する。次に、作業416においては、修正から保護された設計図ライセンス検証ハードウェアを含むIPブロック（例えば、IPブロック所有者200から購入したハードウェアサブデザインを有するIPブロック）を作成するようにFPGAの一部をプログラムする構成データを発生させる。

10

【0033】

図4Cは、本発明の一例示的実施形態による信頼できるホストID245を有する外部ハードウェア装置を使用してASICに範囲内でハードウェアサブデザインを実施するのに使用される設計者211側のコンピュータ311内の作業を示す流れ図である。ASIC内のIPブロック所有者200が所有するハードウェアサブデザインの実施には、設計者211が図2Bにおいて上述したような外部ハードウェア装置を購入することが必要である。図4Cに示す作業411～415は、図4Bに示す作業と同じものである。図4Cの作業426においては、ハードウェアサブデザインが、FPGAではなくASICでの使用のためにライセンス交付されているので、修正から保護された設計図ライセンス検証ハードウェアを含むIPブロックをASIC内で実施するための回路のレイアウトが実行される。

20

【0034】

図5は、本発明の一例示的実施形態による信頼できるホスト識別子545と、設計者の論理550と、複数のライセンス交付ブロック505A～505Iと、クロック回路525と、各ライセンス交付ブロック505A～505I及びクロック回路525に関連した複数のIPブロック510A～510Iとを有するFPGA518を示している。FPGA518は、図2Aで上述したFPGA218と類似のものである。しかし、図5に示すFPGA518は、IP口ケーション540A～540I内の各ライセンス交付ブロック505A～505Iと通信するクロック回路を含む。クロック回路525は、一実施形態では、前回記憶された値よりも大きい場合に限り新しい値（例えば、特定のハードウェアサブデザインが何回実施されたかのカウント又は現在の日付／時間など）を記憶することができる。一実施形態では、クロック回路525は、リセットすることができないので、記録された時間が確実に順方向に移動し続けるようにするのに使用される。

30

【0035】

各IP口ケーション540A～540Iは、ライセンス交付ブロック505A～505IとIPブロック510A～510Iとを含む。クロック回路525は、特定のIP口ケーション540A～540Iがどのくらい長く作動することになるかを支配する情報を記憶する（例えば、クロック回路525は、図2Aに示すように、IPブロック所有者200によってライセンス交付ブロック505Aに提供されたライセンスコードに基づいて、IP口ケーション540Aがどのくらい長く作動することができるかに関する情報を記憶することができる）。一実施形態では、特定の作動期間の限界に達した時、クロック回路525は、1つ又はそれよりも多くのIPブロック510A～510Iを使用不可にすることができる（例えば、図2Aで上述したのと同様に、IP口ケーション540A～540Iは、設計者211がIP口ケーション540A～540Iに関連したIPブロック510A～510Iにアクセス可能である期間にわたって使用可能として、IPブロック510A～510I内のハードウェアサブデザインにアクセスするライセンスが満了となった時に使用不可にすることができる論理モジュールとすることができます）。

40

【0036】

一実施形態では、クロック回路525は、クロック回路525に関連した特定のIPブ

50

ロック 510A～510I が最後に更新された時（例えば、設計者 211 がバス 508 を通じて特定の第三者ハードウェアサブデザインを IP ブロック 510A～510I に最後に更新した時）を記憶することができる。別の実施形態では、クロック回路 525 は、ライセンス交付プロック 505A がどのくらい長く作動することができるか（例えば、IP ブロックに関連した IP 口ケーションが無効化される前にどのくらいか）を判断するカウントダウンタイマを記憶することができる。本発明の別の実施形態では、クロック回路 525 は、IP 口ケーション 540A～540I の最終更新時を含むことができる（例えば、IP ブロック所有者 200 が以前にハードウェアサブデザインの群を設計者 211 にライセンス交付していた場合、クロック回路 525 は、例えば、部分的な再構成計画のために IP 口ケーション 540A 及び 540B に関する最終更新時を記憶することができる）。一実施形態では、ホスト ID 545 を有する外部ハードウェア装置は、バッテリによって電源が提供されかつ IP ブロック 510A～510I 内のハードウェアサブデザインが所定の時間量にわたって作動することを可能にするクロック回路を含むことができる（例えば、クロック回路 525 と同様の）。別の実施形態では、信頼できるホスト識別子 545 を有する外部ハードウェア装置の内部のメモリは、上述したようなクロック回路 525 に対して説明した実施形態の全てを含むことができる。

### 【0037】

一実施形態では、設計者 211 は、ソフトウェアライセンス交付サブシステム（例えば、カリフォルニア州サンタクララ所在の「Macromedia, Inc.」による「GLOBETROTTER（登録商標）」）をそれ自体が使用するソフトウェアアプリケーションを使用して、ハードウェアサブデザインに関する評価ライセンスを IP ブロック所有者 200 から受信することができる。評価ライセンスは、ソフトウェアベースの信頼できるホスト識別子を含むことができる（例えば、評価ライセンスは、アプリケーションソフトウェアに関するソフトウェアライセンスと共に送られた追加ビットのデータ内のソフトウェアベースの信頼できるホスト識別子を含むことができる）。次に、設計者 211 は、ソフトウェアアプリケーションを使用して、図 5 に示すように、ソフトウェアベースの信頼できるホスト識別子と評価ライセンスとを FPGA 518 内のライセンス交付プロック 505A に転送し（例えば、JTAG シリアル通信法を通じて）、その結果、ライセンス交付プロック 505A は、ソフトウェアベースの信頼できるホスト識別子を使用してハードウェアサブデザイン内の 1 つ又はそれよりも多くの特徴を使用可能にすることができる。一実施形態では、IP ブロック 210A 又はライセンス交付プロック 205A の暗号化部分（例えば、ハードウェアサブデザイン内のライセンス検証サブデザイン）によって使用される信頼できるホスト識別子 245 を発生させ、集積回路プログラム又は製造時に信頼できるホスト識別子 245 が提供される時に、IP ブロック 210A（例えば、ハードウェアサブデザイン）の残りの部分を使用可能にすることができる。別の実施形態では、集積回路のプログラム時又は製造時にソフトウェアを通じて信頼できるホスト識別子を IP ブロック所有者 200 が設計者 211 に供給し、例えば、IP ブロック 210A を使用可能にする。このソフトウェアは、集積回路がプログラムされている時に設計者 211 が実施することができ、このソフトウェアは、一般的に、IP ブロック所有者によって提供された許可メッセージ又は信号を通じて使用可能された IP ブロックと共にプログラム又は製造されることになる実施可能なコンピュータプログラムコードを含むと考えられる。この許可メッセージ又は信号は、ソフトウェアによって利用されるソフトウェア又はデータ構造の暗号化部分に供給することができ、又はこの許可メッセージ又は信号は、ネットワーク接続部を通じて、IP ブロック所有者によって制御されるデータ処理システムから供給することができる。

### 【0038】

図 6 は、本発明の一例示的実施形態による修正を防止するために行われる IP ブロック所有者側の信頼できるホスト識別子 245 を有するハードウェアサブデザイン内のライセンス検証サブデザインの暗号化を示す流れ図である。作業 601 においては、IP ブロック（例えば、図 2A の IP ブロック 210A のような）のためのハードウェアサブデザイ

10

20

30

40

50

ンは、図2Bで上述のようにIPブロック所有者200によって設計される。ハードウエアサブデザインは、一実施形態では、IPブロック所有者200によって最初に作成されたデザインとすることができます。別の実施形態では、IPブロック所有者200は、ハードウエアサブデザインを有することができますが、このハードウエアサブデザインは、最初に別の企業によって作成されたものである。作業602においては、IPブロック内のハードウエアサブデザインを実施するようにFPGAをプログラムするデータを発生させる。一実施形態では、図3で説明するようなIPブロック所有者200側のライセンス発生器300を使用して、図2Aに示すように、IPブロック210A～210Iの1つ又はそれよりも多くの内部でハードウエアサブデザインを実施するようにFPGA218をプログラムするデータを発生させることができる。

10

## 【0039】

次に、作業603においては、ハードウエアサブデザイン内のライセンス検証サブデザインをHDL及び/又はRTLレベルで及び可能性として他のレベルでもホストID情報を用いて暗号化する（例えば、図2Aで説明するように、IPブロック所有者200によって提供されたハードウエアサブデザインが、信頼できるホスト識別子245を有する特定のFPGA上でしか機能しないことを保証するために）。最後に、作業604においては、別々に開発された設計者の論理250（例えば、図2Aの設計者の論理250のような設計者によって作成されたハードウエアサブデザイン）と共に、図2Bで説明したように、IPブロック所有者200によって提供されたハードウエアサブデザインを信頼できるホスト識別子245を有するFPGA218に実施することになるFPGAシステムの設計者211にハードウエアサブデザイン情報を提供する。

20

## 【0040】

図7は、本発明の一例示的実施形態による信頼できるホスト識別子245を設計者211から受信した後に行われるIPブロック所有者200側のライセンス発生器300によるハードウエアサブデザインライセンスコードの発生を示す流れ図である。作業701においては、ライセンス発生器300は、ハードウエアサブデザインの要求を設計者211側のコンピュータシステム311から受信する（例えば、設計者211は、IPブロック所有者200が所有するハードウエアサブデザインを供給する契約をIPブロック所有者200と締結したと考えられる）。作業702においては、IPブロック所有者200は、信頼できるホスト識別子245の要求を設計者211に送る（例えば、信頼できるホスト識別子245の要求をIPブロック所有者200が送って特定のライセンスに対して設計者211にどれだけ請求するかを決めることができる）。作業703においては、信頼できるホスト識別子245を設計者211から受信する（例えば、IPブロック所有者200が、信頼できるホスト識別子245を有するFPGA218上でのみハードウエアサブデザインを使用するライセンスを発生させることができるように）。

30

## 【0041】

作業704においては、信頼できるホスト識別子245に基づいて固有のIPブロックライセンスコードを発生させる（固有のIPブロックライセンスコードをライセンス発生器300が発生させることができる）。作業705においては、IPブロック所有者200が所有するハードウエアサブデザイン内のライセンス検証サブデザインを暗号化することができる。作業706においては、IPブロック所有者200側のライセンス発生器300から固有のIPブロックライセンスコードとハードウエアサブデザインとを設計者211に供給する（例えば、図2Bに示すように、例えば、設計者211とIPブロック所有者200の間の契約に基づく義務を履行するために）。

40

## 【0042】

図8は、本発明の一例示的実施形態による信頼できるホスト識別子245を設計者211から受信した後に行われるIPブロック所有者200側のライセンス発生器800による期限を有する固有のハードウエアサブデザインライセンスの発生を示す流れ図である。図8は、ライセンス発生器800が、設計者211からの要求に基づいてライセンスの期限を更に発生させる点において図7と異なっている（例えば、IPブロック所有者200

50

が所有する特定のハードウェアサブデザインがどのくらい長く作動することになるかに関する、かつ図5に示すようにクロック回路525内に及び／又は外部ハードウェア装置上に記憶される期限）。作業701～704は、図7で上述のものと同一である。作業801においては、設計者211からの要求に基づいてライセンスの期限を発生させる（例えば、期限は、設計者がIPブロック所有者200にいくら支払う意志があるかに基づくものとすることができます）。作業802においては、図7で上述の作業705と同様に、IPブロック所有者200が有するハードウェアサブデザイン内のライセンス検証サブデザインを暗号化して修正を防止する。作業803においては、期限を有する固有のIPブロックライセンス及びハードウェアサブデザインを設計者211に供給する。従って、図8は、設計者からの要求に基づく期限付きライセンスを発生させる点において図7と異なっている。更に、図8においては、期限を含む固有のIPブロックライセンスを設計者211に供給する。

10

#### 【0043】

本発明の様々な方法の作業は、機械可読記憶媒体と考えることができるメモリに記憶されたコンピュータプログラムの命令シーケンスを実行するデジタル処理システム内の処理ユニットによって実施することができる。メモリは、ランダムアクセスメモリ、読み出し専用メモリ、大容量記憶装置のような持続性記憶メモリ、又はこれらの装置の組合せとすることができる。命令のシーケンスの実行により、処理ユニットが本発明による作業を実行する。ネットワーク接続を通して、記憶装置又は1つ又はそれよりも多くの他のデジタル処理システム（例えば、サーバコンピュータシステム）からコンピュータのメモリに命令を取り込むことができる。命令は、いくつかの記憶装置（例えば、DRAM、及びバーチャルメモリのようなハードディスク）に同時に記憶することができる。その結果、これらの命令の実行は、処理ユニットで直接に実行することができる。これ以外の場合、命令は、直接に実行することはできず、又は処理ユニットで直接には実行することができない。これらの状況下では、実行は、命令を解釈する解釈ルーチンをプロセッサに実行させることにより、又は受信した命令を、プロセッサが直接に実行することができる命令に変換する命令をプロセッサに実行させることによって行うことができる。他の実施形態では、ソフトウェア命令の代わりに又はソフトウェア命令と組み合わせて、配線接続回路を使用して本発明を実施することができる。従って、本発明は、ハードウェア回路とソフトウェアのいかなる特定の組合せにも又はコンピュータシステム又はデジタルシステムによって実施される命令のいかなる特定のソースにも限定されない。更に、本文書で使用される時の「暗号化」は、設計者によるライセンス交付に関わるサブデザインの部分の修正の防止に使用することができるあらゆる機構を指すものである。ハードウェアサブデザインは、例えば、逆コンパイルが許可されないバイナリデータベースに予めコンパイルすることができる。

20

#### 【0044】

本発明を特定の例示的な実施形態を参照して説明したが、特許請求の範囲で示すような本発明の広範な精神及び範囲から逸脱することなく、これらの実施形態に様々な修正及び変更を行うことができることが明らかであろう。従って、本明細書及び図面は、限定的な意味ではなく例示的に考えるものとする。

30

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

#### 【0045】

【図1A】複数のIPブロックを有する従来技術のFPGAを示す図である。

40

【図1B】ハードウェアデザイン実施のための設計者とIPブロック所有者とFPGAプロバイダとの間の従来技術のトランザクション流れ図である。

【図2A】本発明の一例示的実施形態による信頼できるホスト識別子と複数のライセンス交付ブロックと各ライセンス交付ブロックに関連した複数のIPブロックとを有するFPGAを示す図である。

【図2B】本発明の一例示的実施形態により信頼できるホスト識別子とライセンスコードとを用いたハードウェアデザイン実施のための設計者とIPブロック所有者と信頼できる

50

ホストＩＤプロバイダとの間のトランザクション流れ図である。

【図3】本発明の一例示的実施形態によるデザイン実施のためのコンピュータとライセンス発生器と信頼できるＩＤプロバイダとの間での信頼できるホスト識別子及びライセンスコードの使用のハードウェア図である。

【図4A】本発明の実施形態の実施に使用することができるコンピュータのブロック図である。

【図4B】本発明の一例示的実施形態により信頼できるホスト識別子を有するＦＰＧＡ内でハードウェアサブデザインを実施するのに使用される設計者側のコンピュータ内の作動を示す流れ図である。

【図4C】本発明の一例示的実施形態により信頼できるホスト識別子を有する外部ハードウェア装置を使用してＡＳＩＣ内でハードウェアサブデザインを実施するのに使用される設計者側のコンピュータ内の作動を示す流れ図である。

【図5】本発明の一例示的実施形態による信頼できるホスト識別子と、複数のライセンス交付ブロックと、複数のクロックメモリと、各ライセンス交付ブロック及びクロックメモリに関連した複数のＩＰブロックとを有するＦＰＧＡを示す図である。

【図6】本発明の一例示的実施形態による修正を防止するためのＩＰブロック所有者側での信頼できるホスト識別子を有するハードウェアサブデザイン内のライセンス検証サブデザインの暗号化を示す流れ図である。

【図7】本発明の一例示的実施形態により信頼できるホスト識別子を設計者から受信した後のＩＰブロック所有者側のライセンス発生器によるハードウェアサブデザインライセンスコードの発生を示す流れ図である。

【図8】本発明の一例示的実施形態による信頼できるホスト識別子を設計者から受信した後のＩＰブロック所有者側のライセンス発生器による期限を有するハードウェアサブデザインライセンスコードの発生を示す流れ図である。

【符号の説明】

【0046】

205A～205I ライセンス交付ブロック

208 バス

210A～210I I.P.ブロック

211 設計者

245 ホスト識別子

10

20

30

【図 1 A】



【図 1 B】



FIGURE 1A (従来技術)

FIGURE 1B (従来技術)

【図 2 A】



FIGURE 2A

【図 2 B】



FIGURE 2B

【図 3】



FIGURE 3

【図 4 A】



FIGURE 4A

【図 4 B】



FIGURE 4B

【図 4 C】



FIGURE 4C

【 図 5 】



【 図 6 】



FIGURE 5

FIGURE 6

【 义 7 】



【 図 8 】



## FIGURE 7

## FIGURE 8

## 【国際調査報告】

## INTERNATIONAL SEARCH REPORT

|                                                |
|------------------------------------------------|
| International Application No<br>/US2005/034637 |
|------------------------------------------------|

|                                                  |
|--------------------------------------------------|
| A. CLASSIFICATION OF SUBJECT MATTER<br>G06F17/50 |
|--------------------------------------------------|

According to International Patent Classification (IPC) or to both national classification and IPC

|                    |
|--------------------|
| B. FIELDS SEARCHED |
|--------------------|

Minimum documentation searched (classification system followed by classification symbols)  
G06F

Documentation searched other than minimum documentation to the extent that such documents are included in the fields searched

Electronic data base consulted during the International search (name of data base and, where practical, search terms used)

EPO-Internal

|                                        |
|----------------------------------------|
| C. DOCUMENTS CONSIDERED TO BE RELEVANT |
|----------------------------------------|

| Category <sup>a</sup> | Citation of document, with indication, where appropriate, of the relevant passages                                                                                            | Relevant to claim No. |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| X                     | US 6 357 037 B1 (BURNHAM JAMES L ET AL)<br>12 March 2002 (2002-03-12)<br>column 1, line 30 - line 33<br>column 2, line 26 - column 4, line 19<br>-----                        | 1-104                 |
| X                     | US 2003/126450 A1 (MASTER PAUL L ET AL)<br>3 July 2003 (2003-07-03)<br>paragraph '0003!<br>paragraph '0010! - paragraph '0015!<br>-----                                       | 1-104                 |
| A                     | US 2003/140255 A1 (RICCHETTI MICHAEL ET AL)<br>24 July 2003 (2003-07-24)<br>paragraph '0003! - paragraph '0016!<br>-----                                                      | 1-104                 |
| A                     | US 2002/199110 A1 (KEAN THOMAS A)<br>26 December 2002 (2002-12-26)<br>paragraph '0001!<br>paragraph '0005! - paragraph '0016!<br>paragraph '0059! - paragraph '0079!<br>----- | 1-104                 |



Further documents are listed in the continuation of box C.



Patent family members are listed in annex.

<sup>a</sup> Special categories of cited documents:

- "A" document defining the general state of the art which is not considered to be of particular relevance
- "E" earlier document but published on or after the International filing date
- "L" document which may throw doubts on priority claim(s) or which is cited to establish the publication date of another citation or other special reason (as specified)
- "O" document referring to an oral disclosure, use, exhibition or other means
- "P" document published prior to the International filing date but later than the priority date claimed

"T" later document published after the International filing date or priority date and not in conflict with the application but cited to understand the principle or theory underlying the invention

"X" document of particular relevance; the claimed invention cannot be considered novel or cannot be considered to involve an inventive step when the document is taken alone

"Y" document of particular relevance; the claimed invention cannot be considered to involve an inventive step when the document is combined with one or more other such documents, such combination being obvious to a person skilled in the art.

"&" document member of the same patent family

Date of the actual completion of the international search

Date of mailing of the International search report

17 January 2006

30/01/2006

Name and mailing address of the ISA

European Patent Office, P.B. 5616 Patentlaan 2  
NL - 2280 HV Rijswijk  
Tel. (+31-70) 340-2040, Fax. 31 651 epo nl,  
Fax: (+31-70) 340-3016

Authorized officer

Anticoli, C

**INTERNATIONAL SEARCH REPORT**

Information on patent family members

International Application No  
/US2005/034637

| Patent document cited in search report | Publication date | Patent family member(s) |                                    | Publication date         |
|----------------------------------------|------------------|-------------------------|------------------------------------|--------------------------|
| US 6357037                             | B1               | 12-03-2002              |                                    | NONE                     |
| US 2003126450                          | A1               | 03-07-2003              | AU 2002361772 A1<br>WO 03058390 A2 | 24-07-2003<br>17-07-2003 |
| US 2003140255                          | A1               | 24-07-2003              |                                    | NONE                     |
| US 2002199110                          | A1               | 26-12-2002              |                                    | NONE                     |

## フロントページの続き

(51) Int.CI.

F I

テーマコード(参考)

H 0 4 L 9/00 6 7 5 D

(81) 指定国 AP(BW,GH,GM,KE,LS,MW,MZ,NA,SD,SL,SZ,TZ,UG,ZM,ZW),EA(AM,AZ,BY,KG,KZ,MD,RU,TJ,TM),EP(AT,BE,BG,CH,CY,CZ,DE,DK,EE,ES,FI,FR,GB,GR,HU,IE,IS,IT,LT,LU,LV,MC,NL,PL,PT,RO,SE,SI,SK,TR),OA(BF,BJ,CF,CG,CI,CM,GA,GN,GQ,GW,ML,MR,NE,SN,TD,TG),AE,AG,AL,AM,AT,AU,AZ,BA,BB,BG,BR,BW,BY,BZ,CA,CH,CN,CO,CR,CU,CZ,DE,DK,DM,DZ,EC,EE,EG,ES,FI,GB,GD,GE,GH,GM,HR,HU,ID,IL,IN,IS,JP,KE,KG,KM,KP,KR,KZ,LC,LK,LR,L,S,LT,LU,LV,LY,MA,MD,MG,MK,MN,MW,MX,MZ,NA,NG,NI,NO,NZ,OM,PG,PH,PL,PT,RO,RU,SC,SD,SE,SG,SK,SL,SM,SY,TJ,TM,TN,TR,TT,TZ,UA,UG,US,UZ,VC,VN,YU,ZA,ZM,ZW

(72) 発明者 マケルヴェイン ケニス エス

アメリカ合衆国 カリフォルニア州 9 4 0 2 4 ロス アルトス ヴィア ウェアタ 1 2 0 9

F ターム(参考) 5B017 AA03 AA07 BA06 BA07 BB10 CA15

5B046 AA08 BA02 BA03

5J104 AA07 AA16 EA03 EA04 EA15 KA02 KA04 KA15 NA02 NA05

NA27 NA37 NA38 NA39

【要約の続き】

【選択図】図 2 A