Skip to content

Trace of SPI signals for Mitsubishi Air Conditioner with ESP8266

License

Notifications You must be signed in to change notification settings

cyberdiamond/MHI-AC-Trace

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MHI-AC-Trace

Trace of SPI signals for Mitsubishi Air Conditioner

Publish the data from the SPI signals MOSI and MISO via MQTT and output to the debug console. Use this program if you intend to evaluate / debug the SPI data of your air conditioner. It is not needed for the user of MHI-AC-Ctrl.

For understanding of the monitored data SPI.md is a good starting point.

Attention:

⚠️ You have to open the indoor unit to have access to the SPI. Opening of the indoor unit should be done by a qualified professional because faulty handling may cause leakage of water, electric shock or fire! ⚠️

Prerequisites:

You need a MHI-AC-Ctrl PCB for using MHI-AC-Trace. For MHI-AC-Trace MOSI and MISO (and SCK of course) are inputs, both data streams are monitored.

Installing:

Hardware:

Identical to MHI-AC-Ctrl PCB, no adaption of the MHI-AC-Ctrl PCB is required. If you want to connect more than one MHI-AC-Ctrl PCBs it might be easier using an older PCB version because the latest PCB version has only one SPI connector. The following figure shows the connections between the AC, MHI-AC-Ctrl and MHI-AC-SPY. MHI-AC-SPY is a MHI-AC-Ctrl PCB with the MHI-AC-Trace SW. MHI-AC-Ctrl-Spy-fig Check MHI-AC-Ctrl Readme for a list of supported devices.

Software:

The program uses the following libraries

Please check the GitHub pages to see how to install them (usually via tools -> libraries). Create a sub-directory "MHI-AC-Trace" and copy the files from the src directory in your MHI-AC-Trace sub-directory. Finally enter WiFi and MQTT credentials in MHI-AC-Trace.h. Please also consider the option 'MQTT_CHAR'.

Disclaimer

This SW is experimental and you use it on your own risk.

Output

The data is output on the serial debug console and on MQTT. There is an offset of one MISO frame implemented. That means you see in one line

  • MISO data from t
  • MOSI data from t+1

With this offset you see in a line together the requesting MISO and the answering MOSI frame. This simplifies the analysis.

Serial Console output

The output on the serial debug (baud rate 115200, switch off the time stamp) has the following human readable format: grafik All numbers in hexadecimal format.

MQTT output

The data is output via topic "raw" in ascii char format. Overall 43 chars per line. Order is identical to serial console output:

  • Frame counter number (high byte)
  • Frame counter number (low byte)
  • MOSI SB0-SB2
  • MOSI DB0-DB14
  • MOSI CBH, CBL
  • MISO SB0-SB2
  • MISO DB0-DB14
  • MISO CBH, CBL
  • Repetition No

Frame counter number is a consecutive number. In order to reduce workload a frame is published only once also if it was received multiple times. The "Repetition No" represents the number of repetitions of the previous line.

MQTT topic "Error1" is updated with the received MOSI signature if it isn't the expected signature. MQTT topic "Error2" is updated with the received MOSI checksum if it isn't the expected checksum. No check of MISO signature / checksum.

License

This project is licensed under the MIT License - see LICENSE.md for details

Acknowledgments

The coding of the SPI protocol of the AC is a nightmare. Without rjdekker's MHI2MQTT I had no chance to understand the protocol! Unfortunately rjdekker is no longer active on GitHub. Also thank you very much to the authors and contributors of MQTT client and ArduinoOTA libraries.

About

Trace of SPI signals for Mitsubishi Air Conditioner with ESP8266

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 82.8%
  • C 17.2%