2026年4月18日土曜日

FNIRSI DMC-100で外部出力を試してみた

 新しいテスターが欲しいなと思っていたらFNIRSI DMC-100を見つけて、中身がSDICのSD7502とAT32F415CBT7で制御していて分解画像を見たらUARTで通信してそうだったので解析してみた。
FNIRSIのハンディーオシロスコープが話題になっていたような気がする。

ちなみにUSBはファームウェアアップデート専用っぽくて、PCとつなぐと充電中は使わないでねという警告が表示される。データ保存はできるけどUSBで取得できるわけではなさそう。メモ程度かな…

ネジ6個で止まっているので分解するとクランプメータのところがフレキシブルケーブルなのでちょっと注意。

左側の小さいICがLCDとかを制御しているAT32F415CBT7で、大きいICがADC
とかを担当してるマルチテスターICのSD7502っぽい?その間に22Ωの抵抗が2つあるんだけど、これがAT32F415CBT7のUARTにつながってそう。

SD7502側の22Ωの下側(どっちでも良さそうだけど)からSD7502の出力が取れそうだったのでそこに0.26mmのポリウレタン銅線をはんだ付けして、GNDはUSB端子あたりから取って解析してみた。

CoolTermでBaudrateを9600で受信してみるとHEXモードで"5A A5 06 E0 FB 0B 0A 00 01 00 00 00 00"のようなデータが流れてきた。周期はだいたい6Hzぐらい。
5A A5がヘッダのUART通信はよくありがちな気がするのでボーレートはあってそう。

いろんなモードに変更してみて、電圧モードだと入力の値が変更しやすそうだったので電圧モードで電圧を変更していくとどうやら電圧に応じたデータというよりもこのテスターICが出力している4桁のセグメントディスプレイ用の出力がそのままUARTで出ているのではないかという疑惑がでてきた。

0.000V、0.100V、0.200Vみたいな感じでデータを入れていって解析してみると規則性が出てきたのでまずは4桁の数字を解析してみることに。

import serial
import time

PORT = "COM4"
BAUDRATE = 9600
FRAME_LENGTH = 13
HEADER = b'\x5A\xA5'

DECODE_TABLE = {
    0x7B: "0", 0x0A: "1", 0x5D: "2", 0x4F: "3", 0x2E: "4",
    0x67: "5", 0x77: "6", 0x4A: "7", 0x7F: "8", 0x6F: "9",
    0x31: "L", 0x00: " "
}

UNIT_V = 0x02
UNIT_A = 0x01

def parse_seven_segment(frame):
    digits = []
    for i in range(2, 6):
        hi, lo = frame[i], frame[i+1]
        raw7 = ((hi >> 1) & 0x70) | (lo & 0x0F)
        digits.append(DECODE_TABLE.get(raw7, "0"))
    return digits

def get_decimal_info(frame):
    dots = [(frame[i] & 0x10) != 0 for i in range(3, 7)]
    dot_bin = "".join(["1" if d else "0" for d in dots])
    
    pos = None
    if True in dots:
        pos = dots.index(True) + 1
        
    return pos, dot_bin

def get_secondary_value(frame):
    val = (frame[11] << 8 | frame[12]) * 0.01
    is_neg = (frame[10] & 0x40) != 0
    return -val if is_neg else val

def process_frame(frame):
    digits = parse_seven_segment(frame)
    dec_pos, dot_bin = get_decimal_info(frame)
    is_neg = (frame[2] & 0x10) != 0
    
    unit = ""
    if frame[8] == UNIT_V: unit = "V"
    elif frame[8] == UNIT_A: unit = "A"

    value_str = "".join(digits)
    if dec_pos:
        value_str = value_str[:dec_pos] + "." + value_str[dec_pos:]
    
    if is_neg:
        value_str = "-" + value_str
        
    dual_a = get_secondary_value(frame)

    print(f"[{frame.hex(' ')}] | Dots:{dot_bin} | {value_str:>9}{unit} | Sub:{dual_a:6.2f}")


def main():
    try:
        ser = serial.Serial(PORT, BAUDRATE, timeout=0.1)
        print(f"Listening on {PORT}...")
        
        buffer = bytearray()
        
        while True:
            if ser.in_waiting:
                buffer.extend(ser.read(ser.in_waiting))
            
            while len(buffer) >= FRAME_LENGTH:
                if buffer.startswith(HEADER):
                    frame = bytes(buffer[:FRAME_LENGTH])
                    process_frame(frame)
                    del buffer[:FRAME_LENGTH]
                else:
                    del buffer[0]
            
            time.sleep(0.01)

    except KeyboardInterrupt:
        print("\nStopped.")
    finally:
        if 'ser' in locals(): ser.close()

if __name__ == "__main__":
    main()

やはり7セグのデータが来ているようなんだけど、1バイトに全部収まってるわけではなくて3bit+4bitで分かれて入ってる上に1bit分は小数点なので少し面倒。でも4桁とも規則性があったので7bit分で取り出してテーブルから読み込む形にしてみた。小数点は場所に応じて計算であとから追加する形に。

あとV-Aボタンを長押しすると電圧と電流を同時に取得してWが出せるモードがあるんだけど、そのときは4桁の数字が電圧になって、12バイト目と13バイト目がuint16_tで100培値の電流データが出てくることがわかった。電流値がマイナスの場合は11バイト目の0x40が1になる。

他にも色々ありそうだけどとりあえず4桁の7セグデータと符号が分かればだいたいデータが取れそうなのでPythonツールでのテストはこのぐらいかな。とりあえず電流か電圧かの判別は単位のところでできそう。(9バイト目)

BLEとか仕込んでスマホでデータ取れるようにしたら便利かも。OpenLogとか仕込んでログ変換ツールをPythonで作っても便利かもしれない。

ADC付きのマイコンでアナログ出力しても面白いかも。DCが測れるタイプのクランプ式電流プローブとは意外と高いのでこれは破格かも。

2026年2月7日土曜日

iPhoneのバッテリを純正互換バッテリに交換してみた。

 しばらく使っているiPhone 12 miniだけども、この前暑い地域に海外出張に行ってモバイルバッテリで充電していたりしたらバッテリの最大容量が79%を切ってしまった。暑いところで充電しながら使うともろにバッテリに悪いよねぇ…

最近はかなりバッテリが切れるのが早くなってしまったので、重い腰を上げて修理アシスタント対応のバッテリを購入してみた。修理アシスタント対応だと互換バッテリをつけたときに出る不明な部品のポップアップが出ないらしい。iOS18.1以降ならバッテリの最大容量もちゃんと表示できるらしいし。TI製のBMS搭載でも修理アシスタント対応とか診断対応ってなってるやつじゃないとだめらしい。アリエクとかだとJCIDからも出ていたりするけどお値段があまり変わらなかったのですぐに来るiFactory製の修理アシスタント対応バッテリにしてみた。

工具付きであんまり値段変わらなかったので工具付きにしてみた。

意外と分解が大変で、結構温めるのが重要かも。iFixitの手順を見てやったんだけど、コネクタ側温めて吸盤で引っ張ってもエッジがなかなか浮かなくて…

スクリーンオープナーも買っておけばよかったかな…手が痛い。

最終的には消毒用アルコールを買ってきて隙間から垂らしたら開けることができた。本当は無水エタノールとかのほうがいいかも。(結構水分が残ってしまう。)

バッテリの取り外しもアルコールを隙間から垂らしていたらバッテリの接着剤が柔らかくなって簡単に外れた。

バッテリ取り付けのときはコネクタとバッテリの位置関係に注意して貼り付け。コネクタが刺さる位置を確認しておかないと行けないかも。
バッテリ取り付け位置少しミスったかも。もう少し下だったかなぁ

バッテリの交換をすると修理アシスタントを走らせるように促される。これを走らせるとバッテリがちゃんと認識されて、Apple純正バッテリが取り付けられた認識になった。Appleでちゃんと交換したバッテリはシリアルが本体と紐づけされるらしいけど、本体と紐づけされていないバッテリが搭載されると中古表示になるのかな?

とりあえずこれでバッテリの容量が100%になったー。
そして不明な部品がついているというポップアップも出ない。ちなみにiOS26.2.1で確認。

ちなみに、純正バッテリからBMSを移植する方法も考えたんだけど結局一旦修理アシスタント対応バッテリを繋いで中古表示になってから、Lanrui V1とかで純正BMSをリセットしてから移植して戻さないといけないみたいなので、今回は修理アシスタント対応バッテリでいいやという結論に。中古表示が嫌な場合はLanrui V1で純正BMSをリセットしたあとにこのバッテリに付け替えればよいのだろうけども…

次回交換するときはこの純正BMSを取っておいて、Lanrui V1でリセットしてから戻してみようかな。

2026年1月16日金曜日

Windows 11でiPhoneのUSBテザリングを使ってみた。

 iPhoneでテザリングって言うとよくWiFiを使っているんだけど、バッテリが持たないのでUSBでWindows PCに繋いでテザリングしてみることに。まぁUSBで充電しながらWiFiテザリングでもいいけど、せっかくUSBで繋いでるんだからということで。

通常Windows PCにiPhoneを接続するとMTPデバイスとして認識して写真の取り込みぐらいにしか使えないんだけど、Appleのドライバを入れるとテザリングの際にEthernetデバイスとして認識するようなので試してみた。

iTunesをインストールしているとAMDSドライバが入って、テザリング用のドライバも入るみたいなんだけど、今回はiTunesインストールなしでドライバだけを入れてみた。

まずはiTunesのダウンロード版をダウンロードしてくる。

ダウンロード版はiTunesのダウンロードページをスクロールすると「ほかのバージョンをお探しですか?」という項目が下の方にあるのでそちらのWindowsをクリックするとダウンロードできる。今回はWindows 11を使用しているのでiTunes64Setup.exeがダウンロードされた。

このiTunes64Setup.exeはそのまま実行するのではなくて、WinRARや7Zipなどの解凍ツールを使用して開く。そうするとAppleMobileDeviceSupport64.msiというファイルが中に入っているのでこれを解凍する。

AppleMobileDeviceSupport64.msiをそのままインストールしてみてもMTPドライバのままだったので手動でのインストールを試してみた。

AppleMobileDeviceSupport64.msiをさらにWinRARや7Zipなどで解凍する。今回はWinRARではエラーが出てしまったため、7Zipを使用した。

デバイスマネージャーを開いて、ポータブル デバイスのApple iPhoneをダブルクリック。

ダブルクリックするとプロパティーが開くのでドライバのタブを開く。
ドライバの更新をクリック。
コンピューターを参照してドライバーを検出をクリック。
先程AppleMobileDeviceSupport64.msiを解凍したフォルダを指定して次へを押すとApple Mobile Device USB Driverに変わる。そしてiPhone側でインターネット共有をオンにすると更にデバイスが認識される。
iphoneをダブルクリックして先ほどと同じ手順でドライバを適応するとEthernetデバイスとして認識して、テザリングが使えるようになる。

MacBookとかだとそのまま使えるっぽいけどWindowsだとドライバのインストールが多少面倒な気がする。

これでバッテリ残量を気にせずにテザリングが使えるぞ。

2025年12月29日月曜日

ESP32-P4を使ってみた。

 ESP32-P4っていうESP32シリーズでも高性能なやつを見つけたので試しにポチってみた。WiFiがついてないけど400MHzデュアルコアと高性能っぽい。MIPIポートが付いていてカメラとディスプレイが使えたりH.264エンコーダに対応していたりと色々できそう。

WiFiモジュールがついたり、LANポートが付いたりしたモデルが出ているけど今回はとりあえずネットワークなしのESP32-P4-Picoにしてみた。WiFi付きはESP32-C6-MINI-1が乗ってるっぽくて、ESP32-C6-MINI-1自体は技適取ってるっぽい?(007-AN0136)

性能的にはカメラとかディスプレイを使ったようなプロジェクトを使うのに良さそうな感じで、M5Stack Tab5とかESP32-P4-EYEみたいなディスプレイやカメラを使った開発ボードが出ているみたい。ESP32-CAMよりだいぶ性能が良さそうなのでリアルタイムストリーミングとかもでより高FPSでできそうな気がする。

USB Type Cで接続するとUSB-Enhanced-SERIAL CH343として認識した。ドライバはWindows 11では勝手にインストールされた。

とりあえずArduino IDEが対応していたので前にESP32-C6で動かしたCANのスケッチを動かしてみた。ターゲットをESP32-P4に変更するだけでそのまま使えてしまった。ArduinoだとClockは360MHzが最大っぽい?(ESP32 Arduino Core3.3.1使用)ESP32-P4はTWAIコントローラを3つ積んでいるらしいので3ポート同時にCAN通信ができそう。

LEDは電源LEDしかついていないみたい。スピーカー用にES8311コーデックICが付いてるし、マイクもオンボードでついているみたい。カメラのコネクタはラズパイカメラがそのまま繋がるっぽいし。USBホストとかスピーカーを使う場合は別途ケーブルが必要みたいなんだけど、今回は付属してないバージョンを購入してみたのでコネクタを探してみようかな。

2025年12月28日日曜日

Xiaomi Redmi Note 5にAndroid 15を入れてみた。

 しばらく放置していたXiaomi Redmi Note 5だけども、カスタムROMでまだアップデートが続いてるやつがあるっぽいのでインストールしてみることに。新しいOSを入れるのにRecoveryも新しいものを入れる必要があった。

色々調べてみるとProject MatrixxというカスタムROMだとAndroid 15とAndroid 16のROMがwhyred用に公開されている模様。他にも何種類かあったんだけどまずは試しにMatrixxのAndroid 15を試してみることに。

RecoveryはTWRP 3.5.2_9-0が入っていたんだけども、そのまま新しいROMを焼こうとしても"this recovery does not support retrofit dynamic partitions"というエラーがでて書き込めなかった。whyredはA-onlyのようで、A/Bシステムアップデート対応のように使えるようなRetrofit Dynamic Partitionsに対応したRecoveryが必要っぽい。

whyredに対応したRetrofit Dynamic Partitions対応のRecoveryは何種類か存在しているようだったけど、今回はPitchBlack Recovery ProjectのRetrofit Dynamic Partitionsに対応した非公式ビルドをダウンロードして使ってみた。

PBRP-whyred-4.0-20250601-2009-UNOFFICIAL-Erofs.zipをダウンロードしてきて、TWRPのMTPか、microSD経由でTWRPからzipをインストール。再起動してもう一回リカバリに入るとPitchBlack Recovery Projectが起動する。TWRPでUser[0]のパスワードを入れるように入れるように言われたけどとりあえず無視して書き込んだ(どうせOSを消すので…

あとはWipeのformatでyesと入力して実行するとすべてのOSデータがまっさらの状態に。

暗号化された状態になっていたので、再起動してもう一度PitchBlack Recovery Projectに入り直す。

MTPでMatrixx-v11.9.0-Official-whyred-Vanilla-202510191031.zipを転送してInstallしてみた。Installが終わったら再起動せずに戻って、NikGapps-core-arm64-15-20250716-signed.zipを追加でインストール。再起動してしまったらMatrixxのインストールからやり直さないと…(一回ミスった

ベースがVanillaだからかすごくサクサク動くー

これならまだ使えそうな気がするぞ。