SFP-Master

SFP-module data programmer for CH341a devices

SFP-Master
SFP-Master

SFP-Master is a free software programmer of optical SFP modules for CH341a devices. It can be used to read, write and save SFP module data to the computer. The SFP-Master makes respect to QHexEdit2 hex editor and ch341prog. SFP-Master requires an SFP to I2C adapter. This adapter is used to read and program SFP-module data. It must be inserted into the slot labelled 24xxx of the CH341a programmer.

Adapter schematic
Adapter schematic
Adapter schematic
Adapter schematic

The OSHWLAB project of this adapter is here.

Jumpers J1 to J3 (TxPWR, RxPWR, TxEN) must be installed initially. They are used to supply power to the SFP module. If you want to programm a module with hardware write protection, remove one of the jumpers and try to programm the module. If it fails, remove the other jumper and repeat the operation.

Installing in Linux

For build are needed: - g++ or clang - CMake - libusb 1.0 - Qt5 - Qt5 Qt5LinguistTools - pkgconf or pkg-config - udev

On Debian and derivatives:

sudo apt-get install cmake g++ libusb-1.0-0-dev qtbase5-dev qttools5-dev pkgconf

On Debian >=13 and Ubuntu >=23.10:

sudo apt-get install systemd-dev

On older:

sudo apt-get install udev

To build and install the SFP-Master enter:

sudo ./build_all.sh

To uninstall, enter:

sudo ./uninstall.sh

Connection

To work with the programmer, connect the SFP module to the connector in the SFP adapter, connect the SFP adapter to the CH341A programmer device to the slot marked 24xx. Connect the CH341A Programmer Unit to the USB connector of the computer and start the SFP-Master programm.

Connection
Connection

How to use

The hexadecimal chip editor (right side of the screen) is used to display and modify buffer data.

It contains the following controls: Hex-Editor / Undo or Undo or <Ctrl+Z> undo and Hex-Editor / Redo or Redo or <Ctrl+Y> redo.

Checkbox colour SFP-Master address Real SFP address
Green (Alwais on) 0x0000 - 0x007F 0xA000 - 0xA07F
Blue 0x0080 - 0x00FF 0xA080 - 0xA0FF
Red 0x0100 - 0x017F 0xA200 - 0xA27F
Yellow 0x0180 - 0x01FF 0xA280 - 0xA2FF

The Parse button is used to re-parse hexadecimal data in the hex editor, if they have been changed manually.

The Checksum button is used to calculate two checksums (addresses 0x03F and 0x05F according to SFF-8472 Rev 12.3), if the module data have been changed manually in the hex editor.

Changing the data on the left side of the screen automatically causes the data to be changed in the hex editor.

Packages

sudo dnf install dnf-plugins-core
sudo dnf copr enable bigmdm/sfp-master
sudo dnf install sfp-master

Licensing

Copyright (C) 2023 - 2024 Mikhail Medvedev. This project and ch341prog use GPL-3+ License, some parts taken from project QHexEdit2 is LGPL-2.1.

Translations

Anyone can add or improve a translation by making a pull request. Translations files are located in: language/

You can also add translation to the desktop file (SFP-Master.desktop).