キーボード」カテゴリーアーカイブ

ユーザ定義マクロの記述について (その1)

俺メモ

EEPROM領域の後半128byteをユーザ定義マクロの記録に使う場合の補足。

EEPROM領域の後半128byteは以下のように8byteごとに15個の領域に区切って、呼び出しのための仮想キーコード ( [0xB?]の部分 )を割り当てています。

同様に、16byteごとに7個の領域に区切って、マクロ呼び出しのための仮想キーコード ( [0xA?] の部分) を割り当てています

なおモードによっては EEPROMの一部領域を別の目的で使用していたり、そもそもマクロが使用不可だったりするので、必ずしも128 byte全域がマクロの記録に使えるわけではありません (たとえばPS/2アダプタの mode3b については 0xD0-0xF7 の領域しかマクロ記録に使用出来ません)

必ず区切りに沿ってマクロを定義します。定義したマクロは呼び出しキーコードを何らかのキーに定義することで呼び出せます。例えば 0x80-0x87 の8バイトに定義したShort macro1 をスキャンコード 0x56 を返すキーで呼び出したい場合は設定ファイルに

;
56,B0      ; スキャンコード 0x56 を発生するキーに ShortMacro1 を割り当て
57,A0      ; スキャンコード 0x57 を発生するキーに LongMacro1 を割り当て
;

のように記述します

区切りの境界を跨いでマクロを定義することは出来ません(たとえば 8byteのマクロを0xD2-0xD9の範囲に記録することは出来ません)

 

16stepのLong Macroと8stepのShort Macroは混在可能です。ただしこの場合でも区切りの境界を超えて混在させることは出来ません。Long macroは必ず 0x?0から始まっている必要があります。以下はLongとShortを混在させて定義した例です。

EEPROMアドレスマップ (その2)

俺メモ

FMR用アダプタ、PS/2用アダプタにおけるEEPROMのアドレスマップ

※スキャンコード=キーボードが返す生のコード
※キーコード=アダプタがUSBホストに返す、USB規格で定義されたコード
※通常キー=スキャンコードが 0x01-0x7Cの範囲のキー
※拡張キー=スキャンコードが 0x80-0x9Fの範囲のキー

mode 1 のEEPROMアドレスマップ

0x00 ここに 0xA5 を書くとユーザ定義のキーマップが有効になる
0x01-0x7C 通常キー (※Scancodeが0x01-0x7Cの範囲) についてのユーザ定義キーマップ。
EEPROMのアドレスがキーのスキャンコードに対応する
0x7D アダプタ設定2
0x7E 予約
0x7F 富士通拡張コマンド (※usb2ps2のみ)
0x80-0x9F 拡張キー (※Scancodeが0x80-0x9Fの範囲) についてのユーザ定義キーマップ。
スキャンコード = EEPROM アドレス としてキーコードを書き込む
0xA0-0xF7 ユーザ定義マクロの記録領域。
8step (8byte) あるいは 16step (16byte) 単位で設定する
全領域を8stepのマクロ定義で使った場合は11個のマクロを定義可能。
0xFD Fnキーとするキーのスキャンコードを設定する。
このモードではFnキーは使用出来ないので設定は無視される。
0xFE リモートWakeUpに使うキーを指定する。
特定キーのScancodeを書いた場合はそのキーでSleep解除。
0xFF を書いた場合は任意のキーでSleep解除。
0x00 を書いた場合はキーボードによるSleep解除は無効。
0xFF アダプタ設定1

※ このモードではFnキー機能は使用出来ない

mode 2 のEEPROMアドレスマップ

0x00 ここに 0xA5 を書くとユーザ定義のキーマップが有効になる
0x01-0x7C 通常キー (※Scancodeが0x01-0x7Cの範囲 ) についてのユーザ定義キーマップ。
EEPROMのアドレスがキーのスキャンコードに対応する
0x7D アダプタ設定2
0x7E 予約
0x7F 富士通拡張コマンド (※usb2ps2のみ)
0x80 予約
0x81-0xFC 通常キー (※Scancodeが0x01-0x7Cの範囲) についての、Fn面のユーザ定義キーマップ。
Scancode + 0x80 がEEPROMアドレスに対応する。
Fnキーの機能を使用しない場合は全領域がユーザ定義マクロの記録に利用可能。
0xFD Fnキーとするキーのスキャンコードを設定する。0x00 か 0xFF に設定するとFnキー無効
0xFE リモートWakeUpに使うキーを指定する。
特定キーのScancodeを書いた場合はそのキーでSleep解除。
0xFF を書いた場合は任意のキーでSleep解除。
0x00 を書いた場合はキーボードによるSleep解除は無効。
0xFF アダプタ設定1

※このモードでは拡張キーについてキー配置のカスタマイズは出来ない。また、Fnキーの機能とユーザ定義マクロ機能は排他利用となる

mode 3a のEEPROMアドレスマップ

0x00 ここに 0xA5 を書くとユーザ定義のキーマップが有効になる
0x01-0x7C 通常キー (※Scancodeが0x01-0x7Cの範囲) についてのユーザ定義キーマップ。
EEPROMのアドレスがキーのスキャンコードに対応する
0x7D アダプタ設定2
0x7E 予約
0x7F 富士通拡張コマンド (※usb2ps2のみ)
0x80-0x9F 拡張キー (※Scancodeが0x80-0x9Fの範囲) についてのユーザ定義キーマップ。
スキャンコード = EEPROM アドレス としてキーコードを書き込む
0xA0-0xBF Fnレイヤーのユーザ定義キーマップ。
必ず  “<スキャンコード>, <発行したいキーコード>”  の2バイトペアで記述する。
よってFnキーは16キーまで設定可能
0xC0-0xF7 ユーザ定義マクロの記録領域。
8step (8byte) あるいは 16step (16byte) 単位で設定する
全領域を8stepのマクロ定義で使った場合は7個のマクロを定義可能。
0xFD Fnキーとするキーのスキャンコードを設定する。0x00 か 0xFF に設定するとFnキー無効
0xFE リモートWakeUpに使うキーを指定する。
特定キーのScancodeを書いた場合はそのキーでSleep解除。
0xFF を書いた場合は任意のキーでSleep解除。
0x00 を書いた場合はキーボードによるSleep解除は無効。
0xFF アダプタ設定1

※ 拡張キーも含めてキー配置のカスタマイズが可能。またFnキー機能とユーザ定義マクロ機能を同時に利用可能。ただしFnキーは16個までしか設定できない。

mode 3b のEEPROMアドレスマップ

0xA0-0xCF Fnレイヤーのユーザ定義キーマップ。
必ず  “<スキャンコード>, <発行したいキーコード>”  の2バイトペアで記述する。
よってFnキーは24キーまで設定可能
0xD0-0xF7 ユーザ定義マクロの記録領域。
8step (8byte) あるいは 16step (16byte) 単位で設定する
全領域を8stepのマクロ定義で使った場合は5個のマクロを定義可能。

※ 拡張キーも含めてキー配置のカスタマイズが可能。またFnキー機能とユーザ定義マクロ機能を同時に利用可能。ただしFnキーは24個までしか設定できない。

mode 3a と 3b の違いはFnキー定義とマクロ定義のどちらに重きをおくか (どちらにより多くのEEPROM領域を割り振るか) だけの差

EEPROMアドレスマップ (その1)

俺メモ

FMRおよびPS/2 “以外” のアダプタのEEPROMアドレスマップ

※スキャンコード=キーボードが返す生のコード
※キーコード=アダプタがUSBホスト(PC)に返す、USB規格で定義されたコード

mode 0 のEEPROMアドレスマップ

0x00 ここに 0xA5 を書くとユーザ定義のキーマップが有効になる
0x01-0x7C 通常レイヤーのユーザ定義キーマップ。
スキャンコードがEEPROMのアドレスに対応する
0x7D アダプタ設定2
0x7E 予約
0x7F 予約
0x80 予約
0x81-0xFC Fnレイヤーのユーザ定義キーマップ。
スキャンコード + 0x80 がEEPROMのアドレスに対応する。
Fnキーの機能を使わない場合は全領域がユーザ定義マクロの記録領域となる。
0xFD Fnキーとするキーのスキャンコードを設定する。0x00 か 0xFF に設定するとFnキー無効
0xFE リモートWakeUpに使うキーを指定する。
特定キーのScancodeを書いた場合はそのキーでSleep解除。
0xFF を書いた場合は任意のキーでSleep解除。
0x00 を書いた場合はキーボードによるSleep解除は無効。
0xFF アダプタ設定1

※ もっともシンプルなモード。Fnキーを大量に定義したい場合はこのモードで。

mode 1a のEEPROMアドレスマップ

0x00 ここに 0xA5 を書くとユーザ定義のキーマップが有効になる
0x01-0x7C 通常レイヤーのユーザ定義キーマップ。
スキャンコードがEEPROMのアドレスに対応する
0x7D アダプタ設定2
0x7E 予約
0x7F 予約
0x80 予約
0x80-0x9F Fnレイヤーのユーザ定義キーマップ。
必ず  “<スキャンコード>, <発行したいキーコード>”  の2バイトペアで記述する。
よってFnキーは16キーまで設定可能
0xA0-0xF7 ユーザ定義マクロの記録領域。
8step (8byte) あるいは 16step (16byte) 単位で設定する
全領域を8stepのマクロ定義で使った場合は11個のマクロを定義可能。
0xFD Fnキーとするキーのスキャンコードを設定する。0x00 か 0xFF に設定するとFnキー無効
0xFE リモートWakeUpに使うキーを指定する。
特定キーのScancodeを書いた場合はそのキーでSleep解除。
0xFF を書いた場合は任意のキーでSleep解除。
0x00 を書いた場合はキーボードによるSleep解除は無効。
0xFF アダプタ設定1

※ Fnキー機能とユーザ定義マクロ機能を同時に利用可能。ただしFnキーは16個までしか設定できない。

mode 1b のEEPROMアドレスマップ

0x80-0xAF Fnレイヤーのユーザ定義キーマップ。
必ず  “<スキャンコード>, <発行したいキーコード>”  の2バイトペアで記述する。
よってFnキーは24キーまで設定可能
0xB0-0xF7 ユーザ定義マクロの記録領域。
8step (8byte) あるいは 16step (16byte) 単位で設定する
全領域を8stepのマクロ定義で使った場合は9個のマクロを定義可能。

※ Fnキー機能とユーザ定義マクロ機能を同時に利用可能。ただしFnキーは24個までしか設定できない。mode1aとの違いはマクロ定義領域を削って、代わりにFnレイヤー定義の領域を広げたのみです。

PS/2キーボードをPC-8801 FH以降に繋ぐ (2)

不足していた機能の追加や不具合の修正を行いました。PIC12F1822 or PIC12F1840用です。

PC-8801FH用 PS/2キーボード変換アダプタ ファーム

 

2019.11.14追記
日本語106 Keyboardでも使えるように、PCキーをRight ALTに割り当てたバージョンを作成しました(APPはGRPHを割り当てています)キー配置以外の変更はありません

PC-8801FH用 PS/2キーボード変換アダプタ ファーム+

 

変更点

1. CAPSキー、かなキーのロック処理を追加しました

一度押すとONのままロックされ、もう一度押すとロックが解除されてOFFになります。キーの状態はキーボードのLEDで確認出来ます。なお、かなキーのロックはScroll Lock LEDに割り当てています。

処理の都合上、キーを「離した(Break)」時に判定を行っています(CAPSキーを押して、離した時にONでロック。もう一度押して、離した時にロック解除)

 

2. キーレイアウトを見直して変更しました

現在のレイアウトは以下のとおりです。なおPCキーはApp (Menu) にアサインしているので日本語109キーボード必須となります。

未アサインキーがあっても意味が無い気がしたので重複してでも全キーに何らかのアサインを行いました1106キーボードでも全キー叩けるようにしようかと思ったけど、スペースの右側の並びがどうもしっくり来なかったので結局AppにPCをアサインしています。テンキー=とテンキーカンマは、これはさすがにどうしようもないのでF11とF12にアサインしました。

STOPはScroll LockとPauseの両方にアサインしていますが、押しっ放し動作が必要な場合はScroll Lockを使って下さい。PS/2の仕様上、Pauseキーは押しっ放しが出来ません(押した瞬間に「押した」「離した」が出力されるので)

前述のとおり「CAPS」と「かな」はロックキーです。一度ON-OFFすると「押した」だけが通知されて、もう一度ON-OFFすると「離した」が通知されます。現在どちらの状態にあるかはLEDで判別可能です。なお「かな」はScroll Lock LEDを割り当てています

※左CTRLとCAPSの配置は逆の方がいい、と言う方がいましたらコメントで教えて下さい。

PageUpに「ROLL DOWN」をアサイン、PageDownに「ROLL UP」をアサインしています。(NEC系の伝統?)これも「逆の方がいい」と言う方はコメント下さい。

 

回路図再掲。点線部分はオプションで実装しなくても動きます。LEDはPS/2キーボードの操作にあわせて点滅します。POLYSWは自己復旧型のヒューズです。万一の場合の気休めに。

 

PC-8801 キーボード端子 (ミニDIN 5ピン)

 

PC-8801 FH以降 キーボードのマトリクス

自分用メモ

※1 Row=0x0Eの7bit目は常に0が返る

Row=0x0C以降はPC-8801 mkII のキーボードには無い、追加されたキー。便宜上「拡張キー」と呼ぶことにするが、拡張キーを打鍵した場合はmkII/SRとの互換性維持のため従来キー(mkII/SRに存在するキー)のキーコードも同時に出力される(2行表記のキーの下段)

例えばF9を打鍵した場合は「F9(Make), SHIFT(Make), F4(Make)」が出力される

F9押下→F4押下と打鍵した場合は「F9(Make), SHIFT(Make), F4(Make), F4(Make)」と、F4のMakeが連続で発生する

拡張キーを離した場合はやや複雑となる。単独Breakの場合は簡単で、例えばF9以外のキーが押されていない状態でF9を開放した場合は「F9(Break), F4(Break), SHIFT(Break)」が出力される。

F4を押したままF9を開放した場合はF4のBreakコードは出力されない1。よって「F9(Break), SHIFT(Break)」のみが出力される。

SHIFT左かSHIFT右を押したままF9を開放した場合は「F9(Break), F4(Break), SHIFT(Make)」と、最後にSHIFTのMakeコードが出力される。普通に考えたらSHIFTについてはMakeもBreakも出力しなくて良いようにも思われるが。なおこの「良く分からないMakeの出力」はBSとDEL2、ENTERとテンキーENTER3 でも同様に発生する。逆に、SHIFT左とSHIFT右の場合はSHIFTのMakeは発生しない。

INSを押下した場合はINSのMakeに続けて「SHIFT, INSDEL」のMakeも出力されるが、これは個別に出るのではなくまとめて出力される。同一Rowのキーは最大7キーまでMake/Breakを一度に表現できるので、SHIFTとINSDELのMakeは

Row = 0x08、Col = 0b10110111

となる(Col の bitが 0のキーが押下中のキー。4bit目の0はINSDELの押下を示し、7bit目の0はSHIFTの押下を示している)

 

上記の動作は Type Aキーボードで確認。Type B以降のキーボードでも同じ挙動を示すのかは不明。

 

PS/2キーボードをPC-8801 FH以降に繋ぐ

こちらは実に敷居が高いモノとなっています

まず、このファームは 実機で動作確認していません 私自身では実機での動作確認を行っていません1 。作っても動かないとか、正常に動かない可能性があります。ですので

  • 電子工作に多少の経験がある
  • PC-8801 FH以降の機種を持っている
  • PIC12F1822を書き込めるwriterを既に所持している2
  • PS/2 Keyboardも持っている
  • 出来ればブレッドボードを持っている
  • 動かなくても泣かない

という条件に当てはまる方のみお試し下さい。なお、正常に動かなかった場合は教えて頂ければ可能な限り対応します(が、実機持ってないのでお約束は出来ません)

一応、88の実機は持ってないものの88用のType Aキーボードの実物は持っているのでロジアナで出力信号を比較チェックしています。また、先にType Aキーボードの信号を解釈するテストボードを作ったうえで、作ったファームをそのテストボードで検証しています3

PICはPIC12F1822を使います4。RA0が88への出力信号で、RA4がPS/2 CLK、RA5がPS/2 DATAです。PS/2の2本の信号線には必ず330Ωの抵抗を入れて下さい。パスコンとかは適当に。図中のポリスイッチ(自己復旧型ヒューズ)とLEDは省略可能です

<回路図>

PC-8801FH用 PS/2キーボード変換アダプタ ファーム
機能追加&不具合修正を行った更新版があります

 

ファームの制限事項です

PC-8801 FH以降の機種に付いてくるキーボードは88SR用キーボードからキーが増えています(F6~F10とか)。とりあえずここでは 88SRと共通のキーを「従来キー」、追加されたキーを「拡張キー」と呼ぶことにします。

拡張キーを押したとき、88SR用プログラムとの互換性を取るために、従来キーのキーコードも一緒に送信されます。例えば拡張キーの「F9」を押したときは「F9, SHIFT, F4」というキーコードが出力されます。拡張キーの「INS」を押したときは「INS, INSDEL」というキーコードが出力されます。

面倒なのはキーを離したときで、前述の例だとF9を離したときは「F9開放、F4開放、SHIFT開放」のコードが出力されますが、「F4を押したままF9を開放した」とか「SHIFTを押したままF9を開放した」場合は少し挙動が変わります。「F4を押したままF9を開放した」場合は「F9開放、SHIFT開放」だけ出力され、「SHIFTを押したままF9を開放した」場合は「F9開放、F4開放、SHIFT押下」が出力されます。そういうもののようです。

これらの挙動を厳密に網羅するのが面倒だったので、本ファームでは拡張キー開放時の同時押しに付いては特に考慮していません。SHIFTを押したままF9を開放した場合でも「F9開放、F4開放、SHIFT開放」が出力されて、SHIFTキーはリリースされた状態になります5  6

CAPSキーとかなキーのロックは実装していません。ロック機構が無いと問題が出るアプリがあるようなら実装を検討します。

PS/2 & USB コンパチ型のキーボードだとうまく動かないかもしれません(特に、「デフォルトがUSBで、ケーブルの先端にアダプタを挿すとPS/2でも使える」タイプのキーボード)

  1. 現在 FAでの動作実績1件 []
  2. コメント参照 []
  3. これを検証と呼んでいいのか些か疑問ですが []
  4. PIC12F1840でもOK []
  5. 押してもいないのに「押されている」と処理されるのは問題がありそうでも、押しているのに「押していない」と処理されるのはまあ許されるかな、と []
  6. 追加された拡張キーはF6-F10, BS, DEL といった、そんなに他キーとの同時押しを行わないようなキーばかりなのでそう問題は起きないかな、と []

PC-PTOS キーボード

PC-98用のPC-PTOSキーボードはALPS黄軸モデルとNECスイッチモデルの2種類があります

NECスイッチモデル。キーキャップは二色成型。しかしNEC楕円軸ってこんな感じでLED仕込めるんですね。知らなかったです

 

ALPS黄軸モデル。キーキャップはシルクスクリーン印刷。

どちらも同じリニア軸ですがキーを叩けば一発で違いが分かります。軸取り目的で入手する場合は注意しましょう。

 

5576-Keyboard1の初期設定

PS/2用アダプタのサポートページに 5576-Keyboard1 の初期キー配置図を追加しました。こりゃ酷いわ・・・

一応、繋がってるキーボードが  Keyboard1 なのか 002 なのか 003 なのかは全部判別出来るんですが、Keyboard1の場合はどういう初期キー配置がいいのか悩ましい訳で。キートップの印字を重視した配置とするか、キートップの印字を無視して106/109キーボードに寄せた配置とするかでもかなり変わる気がしますし。個人的にはキートップの印字を重視してCtrlが左2列の右下に位置するのはさすがに抵抗があるといいますか・・・CapsLockの位置(スペースの2つ左隣)もそこじゃないだろ、と。

なので Keyboard1 に関しては「お手数ですが、原則キー配置をカスタマイズして使って下さい」というスタンスでご理解願います。代わりに、サンプルconfをいくつかダウンロード出来るようにしておきますので。

 

東プレ MD01B0

近所のハードオフのジャンク箱に300円で入ってたのでゲット

静電容量無接点、薄型、ゴム椀らしからぬクリック感。鉄板プレート。

特殊配列がいまいちというレビューもあるけど、40%や60%のキーボードが流行ってるような昨今だからなぁ。あんまり気にならないかな