Intel 製のネットワークアダプター I/F カードや Chip を搭載したマザーボードでドライバーをインストールして PC を再起動する度に下記の警告が発生します
ログの名前: System
ソース: e1rexpress
日付: YYYY/MM/DD (w) HH:MM:SS
イベント ID: 27
タスクのカテゴリ: なし
レベル: 警告
キーワード: クラシック
ユーザー: N/A
コンピューター: test
説明:
Intel(R) XXXXXXXXXX Gigabit Network Connection
ネットワーク・リンクが切断されました。
原因はドライバーがオートネゴシエーション(auto-negotiation) の完了を待たずにリンクチェックを行っている為です。オートネゴシエーションとは簡単に言ってしまえば通信相手との規格を合わせるという仕組みです
解決方法は、WIN + R キーを押下し、%SystemRoot%¥system32¥devmgmt.msc /s と入力フィールドに入力し、Enter キーを押下し、デバイスマネージャーを起動します
デバイスカテゴリーの ネットワーク アダプター を展開し、Intel(R) ~ Gigabit Network Connection をダブルクリックします。上記画像では I211 というチップ名称になっています
上記画像の様に リンクを待機 を オン に設定し OK を選択し終了です
…ですが、もうデバイスドライバーインストール時に リンクを待機 を オン の状態でドライバーがインストールされる様にしちゃえばいいんじゃね?と、思い調べてみました
まずは ここ から Intel Gigabit Network Connection のドライバーをダウンロードします
ダウンロードしたファイルの実体は RAR 形式の自己解凍アーカイブファイルなので、RAR 形式のアーカイブファイルを取り扱える解凍ツールで適当な空のディレクトリに解凍します
次に実際使用しているチップ名称をキーワードにして、解凍したディレクトリに点在する *.inf ファイルを探し当てます(秀丸エディタのgrep機能などを使えば便利です) Chip 型番が I211 の場合は e1r62x64.inf というファイルでした
文字列 %WaitAutoNegComplete% を検索し、以下 default の部分を "1" に変更します
; Wait for Link
HKR, Ndi¥Params¥WaitAutoNegComplete, ParamDesc, 0, %WaitAutoNegComplete%
HKR, Ndi¥Params¥WaitAutoNegComplete, default, 0, "2" ← これを "1" に変更する
HKR, Ndi¥Params¥WaitAutoNegComplete¥Enum, "0", 0, %Off%
HKR, Ndi¥Params¥WaitAutoNegComplete¥Enum, "1", 0, %On%
HKR, Ndi¥Params¥WaitAutoNegComplete¥Enum, "2", 0, %AutoDetect%
HKR, Ndi¥Params¥WaitAutoNegComplete, type, 0, "enum"
該当の inf ファイル保存します。保存の際に注意する事は、このファイルは多言語で記述されているので、秀丸エディタ等の文字コードのエンコード/デコードを行うエディターで保存してしまうと正しく保存されないので、バイナリセーフなエディタ、例えば メモ帳 で編集、保存(ANSIで) する事を推奨します
デバイスドライバーをインストール時に変更した inf ファイルを指定してインストールを行えば、いいと思います…と、言うのもこの方法はまだ試していません …ので、次回 Windows 7 統合インストール USB メモリ作成の際に試してみたいと思います
まだ、現時点で試していませんが *.inf ファイルを一括置換する PHP スクリプトを作りました。変更する値のプロパティ以下の4箇所です
ドライバー書庫を解凍したディレクトリに infdeault.php を置き、実行するだけです
原因は対応しているセキュリティカタログファイル e1r62x64.cat の内容と e1r62x64.inf が矛盾している為、セキュリティ警告のメッセージウィンドウが表示されます…しかし、何故か WinToolkit の統合インストールイメージ作成ではエラーが発生せず、編集前のデフォルト値でインストールされるのが不思議です…('A`)
以上の事から、自動化は断念し、インストール時にデバイスマネージャーから手動で設定する事にしました。上記 PHP スクリプト を使用してインストール場合は 自己責任 でお願いします…('A`)
WinToolkit の統合インストールで編集した inf ファイルの値を反映させる方法がわかりました。これは実際に動作確認済みです。後述する方法は 自己責任 でお願いします
WinTookit を起動し、All-In-One-Integrator を選択し、統合するエディションを選択、プリセットをロードし、以下の画像の All-In-One-Integrator の Options の Force Unsigned をチェックして、統合を行えばいいだけです
ついでに infdeault.php もちょっとバージョンアップしました。オリジナルの inf ファイルはファイル名サフィックス部分に .org を付与し、実際に inf ファイルがあるディレクトリのファイルを更新するように変更しました
我が常用PC の Windows XP SP3 (x65) から Windows 7 Ultimate SP1 (x64) への移行は今現在終了したのですが、32bits 環境ではまったく発生しなかった ASUSTeK Crosshair IV Extreme のオンボード LAN である Intel 82583V(e1q62x64.sys) が BSOD 多発病が発生したので、その時の回避策を記述します
Intel 82583V(e1q62x64.sys) での BSOD 多発病は Windows XP SP3 (x86) 32bits 環境ではまったく発生してなかったので、64bits の Windows 環境固有の問題と思われます
現在 (2011/04/15) Intel 82583V(e1q62x64.sys) のドライバーが入手可能先は以下の表のとおりです
入手先 | バージョン |
Intel_LAN_V117321003.zip ASUSTeK サイトからダウンロードできるドライバ。ファイルバージョンでは現在 (2011/04/15) のところ最新。内容はドライバーのみで VPN などのユーティリティは入っていません。また、インストールはデバイスマネージャーから行います。このドライバファイルはβベージョン扱いの為か、デジタル署名が入っていないので、インストール時に警告が出るが無視してそのままインストールします |
|
PROWinx64.exe (16.1) Intel のサイトからダウンロードできるドライバ + ユーティリティ。このドライバでは BSOD が発生する |
|
Intel_Lan_V11470_XpVistaWin7.zip ASUSTeK サイトからダウンロードできる初期のドライバ + ユーティリティ。このドライバでも BSOD が発生する |
以上、3点のドライバーがダウンロードできるが、一番上のファイルバージョン 11.7.32.1003 の ASUSTeK サイトからダウンロードできるβバージョンのドライバーをインストールことで解決しました。VPN などのユーティリティ関係はありませんが、私の環境ではまったく無用なので、当面はコレで使っていきます
それにしても、BSOD にお目にかかるなんて Windows 2000 を使っていた頃から久しぶりに遭遇しましたよ…('A`)