|
次のページ
前のページ
目次へ
6. シリアルポートの設定6.1 PCI バスへの対応は進行中ですカーネル 2.2 のシリアルドライバは PCI バスへの特別な対応は入ってい ません。 しかし、カーネル 2.3 と 2.4 では、ついに一部の PCI シリアルカード(およ びモデムカード)に対応します。多くの PCI カードは、ドライバによる特殊なサポートが必要です。ドライバはカードに デジタル的に格納されている ID を読み込み、そのカードにどうやって対応す るか(あるいはサポートするかどうか)を決めます。確実に Windows モデムで はないにもかかわらず動作しない PCI カードをお持ちであれば、そのカード 用のドライバを作る手助けができます。これを行うには、シリアルドライバの メンテナである Theodore (Ted) Y. Ts'o さんに連絡する必要があります。 しかし、まずは Windows モデムの一覧のサイト http://www.o2.net/~gromitkc/winmodem.html を見て、PCI モデムとそれに関連する話題の最新情報を調べてください。 また、Ted Ts'o には "lspci -vv" の出力のコピーと PCI モデム(または シリアルポート)のモデルとメーカーに関する詳しい情報を電子メールで送る 必要があります。 そうすれば、彼は動作するかもしれないテスト用ドライバの場所をできる だけ教えてくれるでしょう。次に、このドライバを入手してコンパイルします。 カーネルも多分再コンパイルすることになるでしょう。そして、このドライバ をテストしてうまく動作するかどうかを調べ、その結果を Ted Ts'o に報告し ます。上記の手順全てをちゃんと行うつもりがあるなら(そしてこの文書が最 新版なら)、彼に必要な情報を送ってください。 メールアドレスは mailto:tytso@mit.edu です。 PCI モデムはあまり標準化されていません。一部のカードは PC との通信に メインメモリを使います。8 桁の 16 進アドレスが表示されたら、そのカード はおそらく Linux では使えないでしょう。 一部のカードは、特殊な方法を使わないと IRQ が有効になりません。"lspci" の出力を見れば、カードがサポートされているかどうかを調べる役に立つでしょ う。4 桁の I/O ポートが表示され、長いメモリアドレスが表示されなければ、 そのモデムは "setserial" で I/O ポートと IRQ を設定するだけで動作する と思います。この方法で 3COM 3CP5610 PCI モデムを動かすのに成功した人も います。 6.2 設定の概要多くの場合、設定は自動的に行われるので、ユーザがすることは何もあり ません。しかし場合によっては設定を行う必要があります(あるいは単に設定 を確かめるだけのこともあるでしょう)。こういった場合に最初にすべきこと は、Linux におけるシリアルポートの設定の 2 つの部分を知ることです。 最初の部分(低レベル設定)は、I/O アドレス、IRQ、名前(ttyS2 など)を割り
当てることです。この I/O と IRQ の組は、ハードウェアとシリアルドライバ
の両方に設定しなければなりません。これを簡単に「I/O と IRQ の設定」と呼
ぶことにしましょう。 2 番目の部分(高レベルの設定)は速度(38.4K ビット/秒など)の設定やフロー
制御の選択などです。これはしばしば PPP や minicom といった通信プログラ
ムや、getty (他の人があなたのマシンにログインできるようにポート上で動
作します)が行います。
しかし、こういったプログラムに対しては、希望する速度等の設定をメニュー
や設定ファイルを使って行う必要があります。この高レベルの設定は、
バージョン 2.2 以降のカーネルでは、割り込みの共有を使えば低レベルの設 定を行わなくても 3 つ以上のシリアルポートを使うことができます。ただし、 これが動作するのはシリアルポートのハードウェアが割り込みの共有に対応し ている場合だけですし、その設定もシリアルポートの低レベルの設定より簡単 とは言えません。 2.2 以降のカーネルと割り込みの共有 をご覧ください。 低レベルの設定(IRQ と I/O アドレスの設定)は、(高レベルの設定と比べると) 比較的問題を起こしやすいようです。多くの場合は完全に自動で、何も設定す ることがないのにです。そこで、この章の大部分はその話題を扱います。 シリアルドライバが正しい IRQ と I/O アドレスを知るまでは、ポートは全く 動作しません。Linux では検出さえされないでしょう。検出されたとしても、 IRQ が間違っていれば、動作は極めて遅いかもしれません。 この上なく遅い: テキストがすごく遅れてゆっくり画面に表示されます を見てください。 Wintel の世界では、I/O アドレスと IRQ は「リソース」と呼ばれます。した がって、我々は特定のリソースを設定していることになります。 しかし、他の種類の「リソース」がたくさんあるので、この言葉は他に色々な 意味を持つことになります。復習になりますが、低レベルの設定は 2 つの値 (IRQ 番号と I/O アドレス)を 2 つの場所に設定することです:
起動(= ブート時)メッセージを見てください。これは通常は正しいです。しか し問題が起きている場合には、これらのメッセージの一部がハードウェアの正 しい設定を示していない(そして正しくないと思われる)可能性が高いです。 I/O アドレスと IRQ: 起動時のメッセージ を ご覧ください。 6.3 低レベル設定に関するありふれた間違い多くの人がやってしまう一般的な間違いを示します:
6.4 I/O アドレスと IRQ: 起動時のメッセージ 多くの場合、ポートの低レベルの設定は起動時に自動的に行われます(し
かし常に正しいとは限りません)。何が起きているか調べるには、画面上の起
動メッセージを見ましょう。Linux がロードされる前に BIOS が出すメッセー
ジ(例は挙げません)の確認も怠らないでください。このような BIOS の
メッセージの出力は Pause キーを押すと一時的に止めることができます。
スクロールして流れてしまったメッセージを戻して見るには、Shift-PageUp
キーを使います。Shift-PageDown キーを押すと反対向きにスクロールします。
ちょっとした不一致がある点に注意してください。最初のメッセージでは IRQ=4 に ttyS2 があるように表示されていますが、二番目のメッセージでは IRQ=5 になっています。最初のメッセージしか表示されないかもしれません。 ほとんどの場合は最後に表示されるものが正しいメッセージです。しかし問題 がある場合には紛らわしいかもしれません。この章の残りに書かれているこの 難しいことの説明を読む前には、とりあえずシリアルポートを使ってみて、正 しく動作するかどうかを調べるとよいでしょう。ちゃんと動作しているならば、 この先は特に読まなくてもかまいません。 2 番目のメッセージは、起動時に実行される 最初のメッセージは、Linux がシリアルポートの探査を行った結果ですが、
IRQ の探査は行われていません。ポートがここに現われた場合、そのポートは
存在しますが、IRQ は間違っていることがあります。
Linux が IRQ のチェックを行わないのは、どのみち完璧にはチェックできな
いためです。
Linux は IRQ が先に示した値であることを仮定します。なぜなら、これらが
「標準的」な値だからです。 BIOS のメッセージに表示されるデータ(最初に表示される)はハードウェアに
設定されている値です。シリアルポートがプラグ&プレイならば、
また、プラグ&プレイのシリアルポートをお使いの場合には、プラグ& プレイのソフトウェアがハードウェア内部の IRQ と I/O を設定しなければ、 Linux はこれらを検出しません。これは、物理的に存在するシリアルポートが 起動メッセージで表示されない一般的な理由です。PC のハードウェア(PnP BIOS) はこのようなシリアルポートの低レベルな設定を自動的に行います。PnP の設 定は後で説明します。 6.5 シリアルポートの現在の I/O アドレスと IRQ の設定は?前の節では、起動メッセージをみることにより設定を調べる方法を説明し ました。起動メッセージで十分な情報が得られれば、この節を読む必要はあり ません。情報が十分でなければ、これを調べる方法がいくつかあります。 「I/O と IRQ の設定はどうなっているの?」という問いへの答えは実際には 2 通りあります。1. デバイスドライバに設定されている値(これは普通は setserial コマンドで設定と表示を行います)。 2. 実際にハードウェアに設定されてい る値。両者は同じ値でなければなりません。同じ値でなければ問題が起こりま す。なぜなら、ドライバが物理的なシリアルポートに関して間違った情報を持 つことになるからです。間違った I/O アドレスがドライバに設定されている と、ドライバは存在しないポートにデータを送ろうとします。あるいはもっと 悪いケースとしては、シリアルポートでない実在のポートにデータを送ろうと します。間違った IRQ がドライバに設定されていると、 ドライバがシリアルポートからの割り込みサービス要求を受け取れずに、非常 に遅かったり全く応答しなかったりします。この場合は、 この上なく遅い: テキストがすごく遅れてゆっくり画面に表示されます の節をご覧ください。ドライバに設定されている UART のモデルが間違ってい る場合にも問題が起こりがちです。I/O-IRQ の組がドライバとハードウェアで同じ かどうかを確かめるには、これらの値がどのように設定されているのかを ドライバとハードウェアの両方について調べなければなりません。 デバイスドライバの設定は?これを調べるのは簡単です。単に起動メッセージを見るか、 "setserial -g /dev/ttyS*" を実行するだけです。シリアルポートがうまく動 作していれば、この表示内容がハードウェアにも設定されているでしょう。こ の情報を調べる別の方法としては、/proc ディレクトリにある「ファイル」を 見る方法があります。このような別の方法を説明する重要な理由は、 これらはデバイスドライバに設定されている情報しか表示しないことに注意し てもらうためです。一部の人は、/proc ディレクトリにある特定のファイルを 見て、これがハードウェアに設定されていると勘違いしてしまいますが、 「必ずしもそうではありません」。 /proc/ioports は、ドライバが使っている I/O アドレスを表示します。 /proc/interrupts は、現在動作している(デバイスをオープンした)プロセスの ドライバが使っている IRQ を表示します。上記のいずれの場合も、表示され るのはドライバの設定内容であり、ハードウェアの実際の設定内容では必ずし もありません。/proc/interrupts は、それぞれのデバイスに対して割り込みが いくつ発行されたのかも表示します(数千個のこともよくあります)。この情報 から問題解決の手がかりをつかむことができます。なぜなら、大量の割り込み が発行されていれば、その割り込みを使っているハードウェアがどこかにある ということだからです。割り込みが少ししか表示されないことは時に、その割 り込みが実際にはどのシリアルポートによっても物理的に生成されていないこ とを意味します。したがって、使おうとしているシリアルポートに対してほと んど割り込みが発行されていなければ、ハードウェアには割り込みが設定され ていないかもしれず、つまりドライバが間違った割り込みを使っているという ことかもしれません。現在実行中の("minicom" のような)プログラムをチェッ クするために /proc/interrupts を見るには、このファイルを見ている間は ずっとプログラムを実行し続ける必要があります。これを行うには、プログラ ムを終了せずにシェルに行ってみましょう。 シリアルポートのハードウェアの設定は?デバイスのハードウェアに実際にどの I/O アドレスと IRQ が設定されて いるのかを調べるにはどうすればいいのでしょうか? Linux が起動を始める前 に、もしかすると BIOS のメッセージがある程度の情報を教えてくれるかもし れません。 Shift-PageUp キーを使って起動メッセージの表示を戻し、BIOS が出した一番 最初のメッセージを見ましょう。これは Linux が起動する前の設定です。 setserial はこの設定を変えることはできませんが、isapnp や pciutils は 設定を変えられます。 大雑把な方法の一つとして、"autoconfig" オプションを付けて setserial に 検出を行わせてみる方法があります。この方法では、検出を行うアドレスを推定 する必要があります。 setserial とは何か? を見てください。PCI シリアルポートの場合には、"lspci" コマンドを使って ください(2.2 より前のカーネルの場合は /proc/pci を見てください)。 お使いのシリアルポートがプラグ&プレイならば、以下の 2 つの節を見て ください。 ジャンパで設定したポートの場合は、これはジャンパで設定した内容です。ポー トがプラグ&プレイ(PnP)ではないけれど DOS プログラムを使って設定さ れている場合には、そのプログラムを実行した人が設定したように設定されて います。 PnP シリアルポートのハードウェアの設定は? PnP シリアルポートは、電源が切られた時に設定をハードウェアに保存し
ません。これは、電源を切っても設定が変わらないジャンパ(非 PnP)と対照的
です。ISA PnP シリアルポートをお使いであれば、シリアルポートが全く I/O
アドレスや IRQ を持たず、事実上使えない状態になる可能性があります。こ
の場合でもまだ、 ISA バスでのプラグ&プレイの場合、 PnP ポートの場合は、DOS/Windows での設定内容を調べてもあまり役に立 ちません。Windows は設定情報をレジストリに保存しますが、これは Linux では使われません。BIOS の不揮発性メモリにも Windows の情報が記憶されて いることもありますが、レジストリ内にある Windows の現在の設定とは同 期が取れていないことがあります(??)。Linux の起動時に PnP BIOS に自動設 定をさせているのならば(そして Linux を起動する際には、PnP オペレーティ ングシステムでないと BIOS を設定しているならば)、Linux は BIOS の不揮 発性メモリ内の設定を使うはずです。 6.6 シリアルの IRQ の選択OS か PnP BIOS が全てのデバイスを設定するという本物のプラグ&プ レイ設定を行っているならば、IRQ を選ぶことはありません。PnP は最も良い と思われる割り当てを選んでこれを設定します。しかし、Linux でプラグ &プレイ用のツール(isapnp と pcitools)を使っている場合には、IRQ の 選択を行う必要があります。使いたい IRQ を既に知っている場合には、この 節を飛ばしてもかまいませんが、IRQ 0 の使い方が特殊であることだけは知っ ておいてください(次の段落を読んでください)。 IRQ 0 は IRQ ではないIRQ 0 は実際には(ハードウェアでは)タイマですが、setserial を使った シリアルポートの設定においては特殊な意味を持っています。この指定は、 そのポートには割り込みがないことをドライバに伝え、ドライバはポーリング を使った動作を行います。ポーリングは非常に効率が悪いのですが、割り込み が衝突した場合や、割り込みの設定ミスがあった場合には試すとよいでしょう。 IRQ 0 を設定する利点は、ハードウェアに設定されている割り込み番号を知る 必要がない点です。IRQ 0 は、実際に使える割り込みが見つかるまでの急場を しのぐためだけに使うべきです。 割り込みの共有とバージョン 2.2 以降のカーネル一般的な規則では、全てのデバイスが固有の IRQ を持ち、IRQ の共有を 行わないことになっています。しかし大抵のマルチポートを使う場合のように、 IRQ の共有が許されている場合もあります。ただし、共有が許されているとし ても、効率は良くないかもしれません。というのも、共有されている割り込み が与えられる度に、どこで割り込みが発行されたのかを調べなければならない からです。したがって、可能であれば、全てのデバイスに固有の割り込みを与 えるといいでしょう。 バージョン 2.2 より前のカーネルでは、IRQ はほとんどのマルチポートボー ド同士だけでしか共有できませんでした。バージョン 2.2 以降のカーネルは、 場合によっては全てのシリアルポートで IRQ を共有できます。バージョン 2.2 のカーネルで共有を動作させるには、CONFIG_SERIAL_SHARE_IRQ を設定し てカーネルをコンパイルしなければなりません。また、シリアルポートのハー ドウェアも共有に対応していなければなりません(対応していれば、2 つの シリアルカードが 1 つの割り込み線に異なる電圧を流しても、「これが 割り込みです」という意味の電圧しか受け取られません)。 よってバージョン 2.2 のカーネルであっても、割り込みの共有はしない方が 良いかもしれません。 どの IRQ を選ぶか? シリアルポートのハードウェアには、限られた IRQ しか設定できないこ
とがよくあります。しかし IRQ が衝突するのも嫌でしょう。したがって、選択
の余地はあまりありません。PC では普通、 以下に、Greg (Serial-HOWTO の元々の著者)がどのように /etc/rc.d/rc.serial を設定しているかを示します。rc.serial は起動時に実 行されるファイル(シェルスクリプト)です(場所や名前は違うことがあります)。 バージョン 2.15 より後の "setserial" では、必ずしもこのように設定が行 われるわけではありませんが、これは IRQ の選択の例にもなります。
標準の IRQ 割り当てを示します: IRQ 0 タイマチャネル 0 (「割り込み無し」を意味することもあります。詳しくは後述します) IRQ 1 キーボード IRQ 2 コントローラ 2 へのカスケード IRQ 3 シリアルポート 2 IRQ 4 シリアルポート 1 IRQ 5 パラレルポート 2, サウンドカード IRQ 6 フロッピーディスク IRQ 7 パラレルポート 1 IRQ 8 リアルタイムクロック IRQ 9 IRQ2 にリダイレクト IRQ 10 割り当て無し IRQ 11 割り当て無し IRQ 12 割り当て無し IRQ 13 数値コプロセッサ IRQ 14 ハードディスクコントローラ 1 IRQ 15 ハードディスクコントローラ 2 割り込みを選ぶための決定的な方法はありません。割り込みをマザーボードや、 他のボードが使っていないことを確かめるしかありません。2, 3, 4, 5, 7, 10, 11, 12, 15 を選ぶことができます。IRQ 2 と 9 は同じであることに注意 してください。IRQ 2 と 9 のどちらを使っても、シリアルドライバはこれを うまく認識します。非常に古いシリアルボードをお使いの場合には、8 以上の IRQ は使えないかもしれません。 IRQ 1, 6, 8, 13, 14 は使わないでください! これらの IRQ はマザーボー
ドが使うからです。マザーボードが使っている IRQ を取り上げると、とても
悲しいことになります。設定が終わったら、割り込みを使うプログラムを実行
する時に 6.7 アドレスの選択 --ttyS3 と衝突するビデオカードIBM 8514 ビデオカード(とその類似品)の I/O アドレスは、聞くところで
は 0x?2e8 です(? は 2, 4, 8, 9 のいずれか)。16 進値の先頭の 0 である桁
をシリアルポートが無視する場合には(多くの場合はそうです)、これは
0x02e8 にある ほとんどの場合は、可能であればデフォルトのアドレスを使うべきです。ここ で言うアドレスは、8 バイトの範囲の最初のアドレスを表しています。例えば、 3f8 は実際には 3f8-3ff の範囲です。それぞれのシリアルデバイスは(I/O ア ドレスを必要とする他のタイプのデバイスと同じく)固有のアドレス範囲を必 要とします。これは重なっては(衝突しては)いけません。シリアルポートのデ フォルトのアドレスを以下に示します:
6.8 I/O アドレスと IRQ のハードウェアへの設定 (主に PnP 向け)I/O アドレスと IRQ をハードウェアに設定した後には、
I/O アドレスと IRQ は電源を入れる度に(PnP を使って)シリアルポートのレ ジスタに設定しなければなりません。というのも、PnP ハードウェアは電源が 切られた時の設定内容を覚えていないからです。これを行う簡単な方法は PnP OS を使っていないと PnP BIOS に教えてやることで、そうすると起動の 度に BIOS が自動的に設定を行います。 ただし、(PnP OS である)Windows を「PnP OS ではない」と BIOS に認識させ たまま Windows を起動すると、Windows 側で問題が発生するかもしれません。 詳しくは Plug-and-Play-HOWTO をご覧ください。 プラグ&プレイは I/O と IRQ の設定を自動化するために設計されました。
しかし現時点の Linux では、話をややこしくしているだけです。標準の
Linux カーネルはプラグ&プレイをあまりうまくサポートしていません。
Linux カーネルをプラグ&プレイ OS にするパッチを使っているならば、
上記のことは全て OS が自動的に処理できるはずです。しかし、
シリアルポート以外のデバイスの設定を自動化するためにこのパッチを使った
としても、手動でドライバの設定をしなければならないかもしれません。
というのも、Linux のドライバの多くは PnP 対
応の Linux 向けに書かれていないからです。 PnP BIOS を使った I/O アドレスと IRQ の設定PnP OS や isapnp を使って I/O と IRQ の設定を行う方法の説明はそれら のソフトウェアに付いてくるはずですが、PnP BIOS にそういった設定を させようと思っている場合にはそうはいきません。全ての PnP BIOS がこれを行える わけではありません。BIOS には普通、最初の 2 つのシリアルポートを設定す るための CMOS メニューがあります。このメニューは見つけにくいかもしれま せんが、Award 製の BIOS ならば "chipset features setup" の下にあります。 多くの場合、ここではほとんど何も選べません。他のものがメニューになけれ ば、最初の 2 つのシリアルポートには標準の I/O アドレスと IRQ が設定さ れます。 シリアルポートデバイスの名前と番号を ご覧ください。 好むと好まざるとに関わらず、PC を起動すると PnP BIOS が PnP によるハー ドウェアデバイスの(I/O と IRQ の)設定を始めます。PnP BIOS が行う処理 が不十分で、残りの設定が(読者の皆さんがおそらく持っていない) PnP OS に 残されるかもしれません。あるいは PnP OS を持っていないと設定されている 場合には、全ての PnP デバイスを完全に設定するかもしれませんが、デバイ スドライバの設定は行いません。これは読者の皆さんが望む動作ですが、PnP BIOS が行った設定を正確に調べることは必ずしも容易ではありません。 PnP OS を持っていないことを BIOS に設定してあれば、PnP BIOS は最初の 2 つだけでなく全ての PnP シリアルポートの設定を行うはずです。 BIOS の動作を間接的に制御する方法は(もし MS Windows9x を同じ PC で使っ ていれば)、Windows における設定を「強制」することです。 Plug-and-Play-HOWTO を「forced」で検索してください。Windows 上で「強制」 した設定を CMOS BIOS メニューを使って上書きするのは簡単です。 この「上書き」機能の設定・解除が行える BIOS オプションがあると思います。 新しい PnP デバイスが追加されると、BIOS は PnP 設定を変更して調整を行 わなければなりません。衝突を避ける必要が生じれば、既存のデバイスの I/O と IRQ の設定が変わることもあります。この目的のため、非 PnP デバイスの I/O と IRQ をどのように設定しているのかを BIOS に教えてあれば、BIOS は 非 PnP デバイスのリストを保存しています。これを BIOS に教える方法の一 つは、DOS/Windows 上で ICU と呼ばれるプログラムを実行することです。 しかし、この情報でデバイスドライバを設定するために、BIOS が行った設定 を調べるにはどうすればよいでしょうか? BIOS 自身もある程度の情報を出し ます。これは設定メニューや、コンピュータの起動時に画面に現われるメッ セージを通じて得られます。 シリアルポートのハードウェアの設定は? をご覧ください。 6.9 IRQ と I/O アドレスを setserial に与えるいったんハードウェアの IRQ と I/O アドレスを設定したら(あるい は PnP で割り当てられるようにしたら)、今度は Linux が起動される度に "setserial" コマンドが実行されるようにする必要があります。 起動時の設定の節をご覧ください。 6.10 高レベルの設定: stty など 原則としては、アプリケーションプログラムが設定の大部分(あるいは全
て)を行います。これを行うコマンドは フロー制御の設定: ハードウェアフロー制御がベストです解説が フロー制御にあるので、そちら もご覧ください。普通は Xon/Xoff を使ったソフトウェアフロー制御よりもハー ドウェアフロー制御を使う方がいいでしょう。完全なハードウェアフロー制御 を用いるには普通、シリアルポートとデバイスを接続するケーブル内にフロー 制御用の線が 2 本必要です。デバイスがカード上にあるならば、確実にハー ドウェアフロー制御が使えるはずです。 多くのアプリケーション(と getty プログラム)には、フロー制御に関するオ プションがあり、必要に応じて設定できます。デフォルトでハードウェアフロー 制御を設定することもできます。IRQ と I/O アドレスのように、フロー制御 もシリアルドライバとシリアルポートに接続されているハードウェアの両方に 設定しなければなりません。 ハードウェアの設定方法は、ハードウェアによって異なります。 多くの場合は、PC からシリアルポート経由でハードウェ アデバイスに送る特定の「初期化文字列」があります。モデムの場合は、通信 プログラムは両方の設定を行うはずです。 お使いのプログラムがシリアルドライバのフロー制御を設定しない場合には、
次のページ 前のページ 目次へ |
[ |