編集履歴一覧に戻る
akasakaのアイコン画像

akasaka が 2024年04月11日20時53分15秒 に編集

初版

タイトルの変更

+

電車・バスのプラズマディスプレイを動かしてみた

タグの変更

+

ニキシー管

+

プラズマディスプレイ

+

74シリーズ

+

リバースエンジニアリング

+

高電圧

メイン画像の変更

メイン画像が設定されました

記事種類の変更

+

セットアップや使用方法

ライセンスの変更

+

(CC BY-NC-SA 4+) Creative Commons Attribution-NonCommercial-ShareAlike CC BY-NC-SA version 4.0 or later

本文の変更

+

*今回の実験に高電圧が使用されています。再現する方は十分ご注意ください。* # はじめに 最近、とあるオークションサイトに面白そうな行先看板を発見しました。 ![オークションサイトより引用](https://camo.elchika.com/b5ba86f5f827e3a91794ee14e6e848c6434d5dbb/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f63346465386237302d393433662d346335312d623838312d666532653637623538613933/) VFDなどの表示管が好きで、購入しようだと思いましたが… 制御はめっちゃめんどくさいのようですね! と思っていたところ、出品者さんのプロフィールを確認したら8085ベースの制御基板も出品されていた。 ![オークションサイトから引用](https://camo.elchika.com/67fbae3d6f207774972d1c8d69cebb9582e08a37/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f61396431353761382d646135622d346239312d616332612d643431613239623030313739/) 8251AFCのUARTが付いてるから、ROMを解析できれば恐らくシリアルで入力するだけで何とか表示することができるでしょう。 というわけで、安心して落札しました。 # もちろん、このままで動かない 数日後、両方ともの品物が届きました。 ![制御基板。写真の電源端子の±が間違ってるのでご注意](https://camo.elchika.com/d86df1c2c6cca8ee0153c591a1a0a8676565227d/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f61643962353035662d376635662d346361392d393363372d356163353666356162643864/) 基板に書いてる型番(森尾電機 6M06056)をググって見たら結果なし。やっぱりこれから自分で解析しないとダメなんですね… 通電する前にROMをバックアップしようだとしたら、00 しか読みだせない。 …どういうこと (゜U。)… ROMをもとに戻して基板に5Vを通電してみたらも、CPUクロックは正常なのに、データバスとかは静かのままで一部のICが大変熱くなるだけです。 硬いコーティングが掛かってるから修理も難しくて、この基板はとりあえず撤退しかないです… # ディスプレイ基盤の修理 ## 表示管ドライバー基板 というわけでディスプレイ自体に載ってる基板を確認しましょう。型番は MD 16101DS-CONT82 06であり、ググると同様に結果なし。 ![ドライバー基板。今だとこれ全部ちっちゃいFPGAに詰められそう。](https://camo.elchika.com/9ef9850831c0f79279eab4d388086aaf5c0dc15a/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f62623363636636332d616666642d343566302d626665612d636634373533313332343039/) 左から4桁目にあるMN2114はSRAMですので、やっぱりフレームバッファみたいに書き込んだ画像データを一時的に保存し、ディスプレイのリフレッシュをしてくれる設計です。リフレッシュ回路を作るのは一番めんどくさいなのでとても助かります。 下のデータバスコネクターまで引いてる回路をテスターで調べたら、どれが入力とどれが出力ぐらいがわかる。 ![データバスコネクター付近の回路図](https://camo.elchika.com/63303e9629fd6be69bf4c783225c49f7b6fbbefc/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f35613263613033652d393363632d343639382d383830612d633666326163633432616239/) ピン1~8(上列)は、74LS257によって4本ずつ切り替わってるので、そこはデータ入力らしい。ピン9~15はバッファーとして使用されたインバーターに引いてるから入力5本と出力2本があるのようです。 手元にあったパーツからテストジグを作ります。 ![キャプションを入力できます](https://camo.elchika.com/2848d15f1046faed28784debba70e76679c52320/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f66636533373731382d376630352d346636352d623330342d313830643165616630626532/) 右下の電源コネクターは昔のHDDと同様の4pinタイプMOLEXとなってるので、もしかしてパソコンの電源をそのままで使えるかな?と思って通電してみた。 …もちろん、画面は点灯しませんでした。(泣) ## 表示管の構造 今までは、今回の表示管がVFD(蛍光表示管)であると思いました。 VFDの構造だと、以下の画像通りです: ![VFDの構造説明](https://camo.elchika.com/e4680b10932c915d8106d4cae452d333aeb3f16e/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f30363134326436612d373761612d343236662d613262342d656464363234646565353062/) *https://www.futaba.co.jp/product/vfd から引用* だが、手元にある表示管を近くから見ると… ![キャプションを入力できます](https://camo.elchika.com/83657f873e04ca17a542984724e4353c04cc46fb/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f63623863613035302d393939612d346664312d383339322d656366343064303637653133/) フィラメントも、グリッドも全然見当たらない。 というわけで、これはニキシー管の兄弟機、プラズマディスプレイです!構造を簡単に描いてみた: ![](https://camo.elchika.com/5e9933f7b5e775d7976bc38c8e3c7e15f7a2c4e7/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f62613733363033362d343631352d346333652d616435652d343835636366313035396232/) ニキシー管のように高圧から照らすつもりです。 その上に、 - Molex端子の12V(だったはず)回路に250Vまでの電解コンデンサーが載ってる。 - 表示管への出力周辺にあるトランジスター(2SC1473)も250Vまでの仕様です。 手元にあったELワイヤー用電源にダイオードブリッジをつけて160VDC出力をゲット。そして菅の端子に直接繋いでみたら… ![キャプションを入力できます](https://camo.elchika.com/2c44d69d8ce2ca7e77226879198e91ea3e7f964b/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f63656630633534612d633731322d343965652d623934302d653533333235393266653464/) 生きてる!生きてるんだ!! それではまともな高圧電源を用意して、Molex端子に5Vと150Vを入れたら… 動かない。 ## ロジック回路の診断 まずは5V側に電流を確認しましょう。 ![キャプションを入力できます](https://camo.elchika.com/aafbbb1b97f54c32a2695c9737480a1cfccd2aac/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f66363662653834642d313366372d346166312d393966392d363739326266376333333266/) 74LSシリーズはかなり電気食ってるけど、38個あたりに1A近い値は確実に多すぎる。基板の一番左の74LS107-1は通電させる瞬間に+60°Cほど熱くなることもあやしい。 基板の裏面を見たところ、一部ICのGNDピンの半田は灰色っぽくなってたり山のように積もれてる。故障した際に電流が多すぎて半田を溶かすぐらいに熱くなったのだろう? ![キャプションを入力できます](https://camo.elchika.com/d304e3cd380c55b6ce9b38747e816aec48d9e60d/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f62306334393136342d316138392d343766662d396133332d666264373231343938303635/) それではこういう現象のあるICをスコープで確認しましょう。[HP 10529A](https://www.radiomuseum.org/r/hewlett_pa_logic_comparator_10529a.html)みたいな道具があれば便利けど今回はスコープで頑張る。 ![キャプションを入力できます](https://camo.elchika.com/602e96776ce0ef8bc4b5d58c94bad10e35f7e1d2/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f64313562623262632d656537332d343934332d393634362d353733353838303033346663/) うーn…0の方が高すぎて1の方が低すぎてまともなデジタル信号として見えない。 ![キャプションを入力できます](https://camo.elchika.com/e3435e912779840fe507c0bf4ca9f9af9e121c91/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f32313538623338392d383133322d346262302d393465322d366464643466643763356332/) これ、もしかして、昭和時代の3値ロジックの例?それとも異世界の74シリーズ? ![https://xkcd.com/2497/](https://imgs.xkcd.com/comics/logic_gates.png) 結局全てのICを確認したところ結果は以下でした。 - 107-1 (JKトリガー): 大変熱い、出力は入力にショートされている - 107-2: 出力~入力の抵抗は低い(4kΩ)、出力値はデータシートと合ってない - 107-3: 出力~入力は2kΩ - 393-1, 393-2: CLK~VCCは2kΩでカウントしてない ## 遂に生きてる 上記のICを交換しました。発振器は遅くて撮影する際にフリッカーが酷くなる可能性があるのでそれも 5.12→12.8MHzに交換。 ![キャプションを入力できます](https://camo.elchika.com/69bc36d8204a991bb6c82a798015eb043ef8ba2f/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f65383936306534652d623066662d346239332d623337352d396633393962633134383131/) 電源を入れて、テストジグの入力値を0xFFに設定。そしてデータバスのピン10を触ってみたら… ![キャプションを入力できます](https://camo.elchika.com/a43eea144f4cf5e5ca4f3ea1a9b21b7c7a0e205f/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f32393664636635332d356330322d343965362d613837322d306233313134653034393031/) 遂に点灯しました!!(光らない行は、テストジグに断線があったのせい) # 制御方法 いろいろ実験してみたらデータバスのピンアサインは以下のように検出できました。(1~8は上列の右から左、9~16は下列の左から右) - 1~8: 入力、ピクセルデータ - 9: 出力、不明(リフレッシュクロック?) - 10: 入力、#CLK(データクロック) - 11: 入力、#RST(リセット) - 12: 入力、#RTZ(アドレスカウンター初期化) - 13: 出力、#RDY(準備シーケンス中に1、入力可能なときは0) - 14: 入力、BRIGHT(0にすると明るさは半分ほどまで下がる) - 15: 入力、SHOW(0にするとリフレッシュは続けたままで書き込んだ画像は表示されなくなる) - 16: GND まずは電源立ち上がってから#RDYが0になるまで待機する。 そのあと、1~8にピクセルデータを設定して#CLKを0にパルスする。これで設定したピクセルデータ(8ピクセル分)はアドレスカウンターに従った位置に書き込みます。0になってるピクセルは消灯、1は点灯です。そしてアドレスはカウントアップします。偶数のアドレスは上の8行、奇数のアドレスは下の8行となります。 ![キャプションを入力できます](https://camo.elchika.com/d5bfa5744b0ab93a9d150d4caf451ecb2d9e5c89/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f34656333623134622d623131362d343232392d613539612d383763626366393962643335/) ディスプレイの解像度は101x16pxであるため、アドレスカウンターは201を超えたら0(画面の左上)に戻ります。 出力途中で左上からやり直したい場合は#RTZをパルスすることでアドレスカウンターを初期化する。ディスプレイ内容を消去して初期化したいとき#RSTをパルスしてリセットを行う。 # 何とか描いてみよう 制御方法をわかるからESP32に接続させる簡単のレベルシフト基板を作ってみた。 ![キャプションを入力できます](https://camo.elchika.com/70c3ece0fd06883f0ed60b0b26a688e6d958724a/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f34636366666132372d653563622d343762612d626537632d396332343931373862616639/) ![簡単と言えるんだろu…まぁxxxPCBから待つのは面倒くさいからいいや](https://camo.elchika.com/a888aa0779e6d6fee1b4add0ec3dec9c37f1c921/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f34353635306433302d323066382d343161642d393863332d656466306235663961353730/) ソースコードはかなり長いのでGithubでご参照ください: [動作確認スケッチ](https://github.com/vladkorotnev/plasma-clock/blob/fbfe900f27db0df48946fac754faa7f631b76bf3/src/main.cpp) [![](https://camo.elchika.com/89bf46faa82930b6b0c0295cf10fe9f62557c22f/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f64376364313661372d386538382d346364622d616464312d346135303565393830313337/)](https://www.youtube.com/watch?v=VG0H--4KytI) *[動画はこちら](https://www.youtube.com/watch?v=VG0H--4KytI)* # 最後に これから画像処理などを作ってアイコンなどを準備して、時計・天気予報表示器にしました。 ファームウェアはかなり大きくてそんなに面白くはないだと思いますので、後日に記事を書いておくかもしれません。 今回は良かったら、完成物の写真と動画をご覧くささい。 **[→動画←](https://www.youtube.com/watch?v=D4MiHmhhjeQ)** *アニメーション中の時計モード。背景に雨が降るのようなエフェクトがあります。* ![キャプションを入力できます](https://camo.elchika.com/92625d23174df46869f75f911cf8e059d37d636e/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f65313936343032342d303637392d343437302d613339362d623962326631613733366534/) *屋内温湿度表示モード* ![キャプションを入力できます](https://camo.elchika.com/3decf19ce485914e041cfb1f993775e3a6b2654a/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f32393332363662332d663766342d346334612d393233302d643262666230623461663530/) *天気予報表示モード* ![キャプションを入力できます](https://camo.elchika.com/685099108a063342a503678fdf9c9f757d87b0ee/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f38343662336362622d643833312d343835652d616131342d346435616130336632623930/) *裏側* ![キャプションを入力できます](https://camo.elchika.com/d39e0fbd26de6438979af7b171d6af1e84863b15/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f62623861386332332d326434332d343731372d393830342d316136326333666330303734/) *温湿度センサー* ![キャプションを入力できます](https://camo.elchika.com/b681f7aa42d666eb07c67438e59ca340d9c11fc7/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f30323465663534302d333764342d346365392d613066622d303036373335323865616434/) *箱作り中の写真* ![キャプションを入力できます](https://camo.elchika.com/ed93f232d335ffbb55b97f236a401997e1ace7b6/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f32613133303739382d616230632d343266652d383562632d3565623962353566363661312f63303836326661632d393964322d343730362d623039642d346430633930386530366130/)