総合手引 | セクション 4 | English | オプション |
AST 互換 4ポートマルチポートカード用 : options amp;"COM_MULTIPORTamp;" device sio4 at isa? port 0x2a0 tty flags 0x701 device sio5 at isa? port 0x2a8 tty flags 0x701 device sio6 at isa? port 0x2b0 tty flags 0x701 device sio7 at isa? port 0x2b8 tty flags 0x701 irq 12
Boca Board 互換 8 ポートマルチポートカード用 : options amp;"COM_MULTIPORTamp;" device sio4 at isa? port 0x100 tty flags 0xb05 ... device sio11 at isa? port 0x138 tty flags 0xb05 irq 12
ヘイズ ESP カード用 : options amp;"COM_ESPamp;" ...
フラグ の意味 :
0x00001 | 共有 IRQ |
0x00002 | FIFO を無効にする |
0x00004 | AST/4 互換の IRQ コントロールレジスタを使用しない |
0x00008 | 失われた出力割り込みから早く復旧する |
0x00010 | デバイスはシステムコンソールになることができる |
0x00020 | デバイスは強制的にシステムコンソールとなる |
0x00040 | 下位層の IO (例えば、リモートカーネルデバッグ) 用にデバイスを予約する |
0x0 ??00 | マスタポートのマイナナンバ |
0x20000 | デバイスが 16650A タイプ (拡張 FIFO) のチップを使用すると仮定する |
マイナナンバリング :
0bOLIMMMMM
callOut
Lock
Initial
MMMMMMinor
各ラインの入出力は、以下のボーレートのうちのいずれかに設定できます : 50, 75, 110, 134.5, 150, 300, 600, 1200, 1800, 2400, 4800, 9600, 19200, 38400, 57600, 115200。ハードウェアによっては、 ボーレートの選択の幅が狭まるかもしれません。
このドライバは、`マルチポート' カードをサポートしています。 マルチポートカードとは、1 つないし複数のポートのグループを持って いるカードで、そのグループは、グループごとに割り込み要求 (IRQ) ラインを 共有しています。 別々のカードで同じ IRQ を共有することはサポートされていません。 多くの場合、4 ポートで IRQ を 1 つ共有しています。 したがって、 8 ポートのカードでは、4 ポートの組が 2 つあるので、IRQ を 2 つ 使用するものがあります。 カードによっては、最初の 2 つのシリアルポートが、ポートごとに別の IRQ を持つようにできるものがあります (DOS PC 標準に従って)。
カードによっては、各グループについて IRQ コントロールレジスタを 持つものがあります。また、このようなレジスタに関連する特別な 初期化が必要なカードもあります。 AST/4 互換の IRQ コントロールレジスタのみがサポートされています。 カードによっては、各グループに対して IRQ ステータスレジスタを 持っているものがあります。 本ドライバは、まだこうしたレジスタを必要とせず、使用してもいません。 グループに対するコントロールレジスタならびにステータスレジスタを ともかくも使用できるようにするには、そのグループ内のポートの スクラッチレジスタ (レジスタ 7) にマップしなくてはなりません。 こうしたポートは マスタ ポートと呼ばれています。
16550A UART 上の FIFO を無効にするために、 カーネル設定ファイル内の各 device sio 行で、 flags キーワードを使用できます (書式の項を参照)。 ほとんどの場合、FIFO を無効にする必要はありません。
IRQ を共有するグループの一部であるポートはすべて、 flags キーワードを使用 しなくてはなりません。 1 ビットで IRQ の共有を指定し、 もう 1 ビットでポートが AST/4 互換の初期化を 必要としない かどうかを指定します。 グループのマスタポートに対応する デバイスのマイナナンバは、高位バイトのビットフィールドとして 符号化されます。 1 つのグループに属するポート用には、 同一のマスタポートを指定しなくてはなりません。
マスタポートならびに IRQ 共有グループに属さないポート用には irq を指定してやらなくてはなりません。 それ以外のポートに対しては指定してはいけません。
書式の項で、 flags 0x701 とあるのは、8 番目のポート (sio7) が マスタポートであり、 またこのポートは 共有 IRQ ならびに AST/4 互換の IRQ コントロールレジスタを持ったマルチポートカード上にある という意味です。
flags 0xb05 は、12 番目のポート (sio11) が マスタポートであり、 共有 IRQ を持っているが、特に IRQ コントロールレジスタを持たない マルチポートカード上にこのポートがあるという意味です。
どちらのポートがマスタポートとなるかは、カードの種類に依存します。 お手持ちのカードのハードウェア説明書を調べてください。 IRQ ステータスレジスタが使われることは決してなく、 IRQ コントロールレジスタは AST/4 互換のカードでしか使われないこと、 また、コントロール / ステータスレジスタをグループ内の すべてのポートに対してマップするカードがあることから、 グループ内のどのポートでもマスタポートにして良いことがあります。 将来の互換性のために IRQ ステータスレジスタを含んだポートを 選択してください。 また、確実性を持たせるために、もっとも上位の番号のポートを選択して ください。
sio ドライバで制御されるシリアルポート は、「着呼」にも「発呼」にも使うことができます。 各ポートについて、着呼デバイスと発呼デバイスがあります。 発呼デバイスのマイナナンバは、対応する着呼デバイス用のものより 128 だけ大きいものになっています。 着呼デバイスは一般的な用途のものです。着呼デバイスをオープンするプロセスは、 通常キャリアを待ったり、発呼デバイスが使用停止の状態になるのを待ちます。 発呼デバイスは、着呼デバイス上でキャリアを待っているプロセスから ポートを奪うのに使われます。 発呼デバイスをオープンするプロセスはキャリアを待たず、着呼プロセス上で キャリア待ちをしている任意のプロセスをより深い休眠状態にします。 これにより、着呼デバイス上でキャリアを待っているプロセスは 発呼セッションと競合しなくなります。 発呼デバイスは、一般的なポートで動き、かつポートをキャリア待ちをせずに オープンする必要があると仮定された制御プログラムで誤用されていますが、 そのような使い方をするのは全く馬鹿げています。
sio ドライバは、初期状態およびロック状態をコントロールする、 各着呼および発呼 "データ" デバイス用の制御デバイスもサポートします。 初期状態制御デバイスのマイナナンバは、 対応するデータデバイスのマイナナンバよりも 32 だけ大きいものです。 また、ロック状態を制御するデバイスのマイナナンバは、 対応するデータデバイスのマイナナンバよりも 64 だけ大きいものです。 データデバイスの termios の設定は、 初めてオープンした初期状態制御デバイスに対応したものがコピーされます。 過去にオープンしたときのものは継承されません。 termios の初期状態をあなたが望むようにプログラムしたいのであれば、 初期状態制御デバイス上で通常の方法で stty(1) を使用してください。
termios のロック状態は、termios の状態変更を無効にするフラグのような 振舞いをします。 たとえば、CRTSCTS のような flag 変数をロックするには、 ロック制御デバイスで stty crtscts を使用してください。 通信速度やスペシャルキャラクタをロックするには、 ロック状態制御デバイス内の対応する値に 0 以外の値を設定します。
正しく接続された外部デバイスと通信するプログラムは、 誤りがなければほとんどどのような初期状態でもロックせずに動作しますが、 他のセットアップを用いた方がデフォルトの初期状態をいくつか 変更したり、状態をロックしたりするのに便利なことがあります。 特に、接続されたデバイスを適切なものにするためには、 POSIX 標準でないフラグの初期状態を設定すべきです。 また、場合によってはバグのありそうなプログラムが POSIX 標準でない フラグを書き換えてしまわないように初期状態をロックする必要が あるかもしれません。 例えば、CRTSCTS フラグは、 RTS/CTS ハンドシェークをいつでもサポートする デバイスではロックすべきですし、 RTS/CTS ハンドシェークを一切サポートしないデバイスではロックすべきでは ありません。 CLOCAL フラグはキャリアをサポートしないデバイスではロックすべきです。 HUPCL フラグは、何らかの理由でハングアップさせたくないのなら ロックすべきではありません。 一般的に、適切でない状態で何かをロックすると非常に良くないことが 起こります。また、2 つ以上の設定をサポートするデバイスはロック すべきではありません。 着呼ポートの CLOCAL フラグは、logins プログラムがある種の セキュリティホールを作ってしまうのを防ぐために、 ロックしないでおくべきです。 ただし、着呼ポートが他の用途に使用されている場合に、 着呼ポートがロックされないようにするには、getty を用いる必要があります。
/dev/ttyd? | 着呼ポート用 |
/dev/ttyid?
/dev/ttyld? | |
対応する着呼初期状態制御デバイスおよびロック状態制御デバイス
| |
/dev/cuaa? | 発呼ポート用 |
/dev/cuaia?
/dev/cuala? | |
対応する発呼初期状態制御デバイスおよびロック状態制御デバイス | |
/etc/rc.serial | |
初期状態制御デバイスおよびロック状態制御デバイスの設定例 | |
デバイス番号は、[0-9a-v] という 集合からなっているので、10 ポート以上の場合もサポートできます。
sio%d: silo overflow. | 割り込みハンドラ内で問題がありました。 |
sio%d: interrupt-level buffer overflow. | ドライバのボトムハーフでの問題です。 |
sio%d: tty-level buffer overflow. | アプリケーション側での問題です。 与えられたモジュールの処理速度よりも速く入力が到着してしまい、 いくつかデータを失ってしまいました。 |
ただの NS16550 を使わないでください。これは初期のチップ実装であり、 機能しない FIFO ハードウェアを搭載しています。
さまざまなシリアルポートの場所を定義する定数値は、 DOS から引き継いだものです。 御覧のとおり、16 進数表記のアドレスを替わりに使用することができますし、 また、分かりやすさから言ってもそうすべきでしょう。
注意として、AST/4 を使用するときには、ディップスイッチを割り込み共有を 使用するようには設定 しないで ください。 AST/4 のような割り込み共有が使用できるのは、 複数の AST/4 カードが同じシステムに設置されているときだけです。 sio ドライバは、ひとつの IRQ に 複数の AST/4 カードが設置されているような場合はサポートしていません。
書式の項の例はかなりベンダに依存したものです。
FreeBSD | SIO (4) | October 10, 1995 |
総合手引 | セクション 4 | English | オプション |
このマニュアルページサービスについてのご意見は Ben Bullock にお知らせください。 Privacy policy.
“ | The “N” in NFS stands for Not, or Need, or perhaps Nightmare | ” |
— Harry Spencer |