Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CN-WIRED ongoing work. #240

Open
revk opened this issue Feb 15, 2024 · 140 comments
Open

CN-WIRED ongoing work. #240

revk opened this issue Feb 15, 2024 · 140 comments
Assignees

Comments

@revk
Copy link
Owner

revk commented Feb 15, 2024

Closing #126 to start again as far too long - let's start again.

Where are we?

We have details of low level timings and codings, and dumps of messages both ways, and a good idea of the protocol. A lot done by @Sonic-Amiga researching. However, we have seen some variations which even have a different checksum system.

This Faikin s/w now has CN_WIRED which can be enabled by turning off the new nocnwired setting. It has basic sending and receiving of messages, but it seems sending is not entirely reliable with sent messages actually working. Given how well the low level timing is understood, this seems protocol (byte level) as a likely issue, and we do not understand all the bytes. Interestingly @Sonic-Amiga has seen 900uS mark, but others have recorded 1000uS mark, including my testing with @akifrabbani

We now have new settings in Faikin...

  • cnsend4 Causes 4 sends of packets when sent instead of 1
  • cnmark900 Causes use of 900uS mark not 1000uS
  • cnbyte1 Allows byte 1 in sent message to be set (in hex)
  • cnbyte2 Allows byte 2 in sent message to be set (in hex)

I can add more settings and options. I expect to remove these once properly cracked.

Setting nos21 and nox50a and noswaptx and noswaprx and unsettling nocnwired forces CN_WIRED and no others.

@revk revk self-assigned this Feb 15, 2024
@Sonic-Amiga
Copy link
Contributor

has seen 900uS mark, but others have recorded 1000uS mark, including my testing

This is a surprise-surprise!

I've dug down my archives and found raw_sampler dumps made by @dremugit. Here they are:

Air conditioner sending once per second to emptiness, no wall panel attached:

13:51:56.201 -> 0 2616 1 992 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 988 0 312 1 992 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 452 0 252 1 388 0 324 1 992 0 300 1 388 0 324 1 380 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 992 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 404 0 300 1 388 0 324 1 376 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 452 0 252 1 388 0 324 1 376 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 404 0 300 1 388 0 348 1 356 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 404 0 300 1 388 0 324 1 380 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 992 0 312 1 388 0 316 1 388 0 312 1 16324 0 2016 1 931120
                0 2616 1 992 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 988 0 312 1 992 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 392 0 312 1 424 0 276 1 388 0 328 1 376 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 988 0 312 1 392 0 312 1 992 0 308 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 400 0 304 1 388 0 372 1 328 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 400 0 304 1 388 0 324 1 376 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 404 0 300 1 388 0 324 1 376 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 424 0 280 1 388 0 324 1 376 0 316 1 388 0 312 1 992 0 312 1 388 0 312 
13:51:58.289 -> 0 2620 1 992 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 992 0 312 1 988 0 316 1 388 0 312 1 388 0 316 1 400 0 300 1 388 0 372 1 332 0 312 1 988 0 324 1 380 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 448 0 252 1 992 0 312 1 400 0 300 1 992 0 312 1 424 0 276 1 392 0 324 1 376 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 400 0 300 1 392 0 376 1 324 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 400 0 300 1 392 0 324 1 376 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 400 0 304 1 388 0 324 1 376 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 392 0 312 1 16324 0 2016 1 931376
                0 2616 1 992 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 992 0 312 1 992 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 988 0 312 1 392 0 312 1 388 0 312 1 424 0 276 1 392 0 324 1 376 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 992 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 404 0 300 1 388 0 372 1 332 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 400 0 304 1 388 0 324 1 376 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 400 0 300 1 392 0 324 1 376 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 392 0 308 1 392 0 312 1 424 0 276 1 388 0 328 1 376 0 312 1 388 0 312 1 992 0 312 1 388 0 312 
13:52:00.323 -> 0 2616 1 988 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 988 0 312 1 992 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 400 0 300 1 388 0 376 1 328 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 988 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 404 0 300 1 388 0 324 1 376 0 312 1 392 0 308 1 392 0 312 1 412 0 288 1 388 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 400 0 300 1 388 0 324 1 380 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 392 0 308 1 392 0 312 1 424 0 276 1 392 0 324 1 376 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 392 0 316 1 384 0 312 1 388 0 316 1 388 0 312 1 400 0 300 1 392 0 372 1 328 0 312 1 388 0 312 1 392 0 312 1 988 0 316 1 388 0 312 1 388 0 312 1 16320 0 2016 1 931440
                0 2616 1 992 0 312 1 400 0 300 1 388 0 324 1 380 0 312 1 988 0 376 1 940 0 300 1 392 0 320 1 376 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 988 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 400 0 300 1 388 0 324 1 376 0 316 1 388 0 312 1 988 0 316 1 388 0 312 1 988 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 400 0 300 1 392 0 320 1 380 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 448 0 256 1 388 0 324 1 376 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 400 0 300 1 388 0 372 1 332 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 388 0 316 1 400 0 300 1 988 0 312 1 452 0 252 
13:52:02.404 -> 0 2612 1 992 0 316 1 396 0 304 1 388 0 324 1 376 0 312 1 992 0 344 1 968 0 300 1 388 0 324 1 380 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 392 0 308 1 392 0 312 1 388 0 312 1 388 0 312 1 400 0 300 1 392 0 324 1 376 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 400 0 304 1 388 0 324 1 376 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 448 0 252 1 388 0 324 1 380 0 312 1 388 0 312 1 388 0 316 1 384 0 316 1 388 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 400 0 300 1 388 0 372 1 328 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 400 0 304 1 988 0 312 1 448 0 252 1 392 0 324 1 16300 0 2012 1 931452
                0 2616 1 992 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 988 0 312 1 992 0 312 1 388 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 988 0 316 1 388 0 312 1 388 0 312 1 424 0 280 1 388 0 324 1 376 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 388 0 316 1 988 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 400 0 300 1 392 0 372 1 328 0 312 1 388 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 400 0 300 1 388 0 324 1 380 0 312 1 388 0 312 1 388 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 388 0 312 1 404 0 296 1 392 0 324 1 376 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 424 0 276 1 388 0 324 1 380 0 312 1 388 0 312 1 992 0 312 1 396 0 304 
13:52:04.457 -> 0 2616 1 992 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 992 0 312 1 988 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 400 0 300 1 992 0 312 1 400 0 304 1 388 0 376 1 324 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 992 0 312 1 388 0 316 1 988 0 312 1 392 0 312 1 388 0 312 1 400 0 304 1 388 0 324 1 380 0 308 1 392 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 400 0 300 1 388 0 328 1 376 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 424 0 276 1 392 0 324 1 376 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 400 0 304 1 388 0 376 1 324 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 388 0 312 1 16312 0 2016 1 930488
                0 2620 1 988 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 988 0 316 1 988 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 404 0 300 1 388 0 348 1 356 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 988 0 312 1 392 0 312 1 992 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 400 0 300 1 388 0 324 1 380 0 316 1 384 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 400 0 300 1 388 0 324 1 380 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 452 0 248 1 388 0 328 1 376 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 400 0 300 1 388 0 348 1 356 0 312 1 392 0 308 1 392 0 312 1 988 0 312 1 392 0 312 

(every second packet is trimmed due to limited buffer space)
Here i broke down the first line for you:

13:51:56.201 -> 0 2616 1 992 - SYNC START
                64 data bits follow:
                0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 988 0 312 1 992 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 452 0 252 1 388 0 324 1 992 0 300 1 388 0 324 1 380 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 392 0 312 1 992 0 312 1 388 0 312 1 992 0 312 1 388 0 312 1 404 0 300 1 388 0 324 1 376 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 452 0 252 1 388 0 324 1 376 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 404 0 300 1 388 0 348 1 356 0 312 1 388 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 392 0 312 1 388 0 312 1 388 0 312 1 404 0 300 1 388 0 324 1 380 0 312 1 388 0 312 1 388 0 316 1 388 0 312 1 388 0 312 1 992 0 312 1 388 0 316 1 388 0 312
				1 16324 0 2016 - DELAY (16 ms), END (2 ms low)
				1 931120 - IDLE state before the next packet arrived

Hah, indeed. Ones are 980 usecs...

Here are some wall panel "replies":

13:53:43.346 -> 0 2604 1 976 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 356 1 944 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 944 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 384 0 360 1 940 0 360 1 388 0 360 1 384 0 360 1 388 0 356 1 940 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 944 0 356 1 944 0 356 1 392 0 356 1 16172 0 2012 1 927960 0 2596 1 976 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 384 0 360 1 944 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 944 0 356 1 944 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 388 0 356 1 944 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 944 0 360 1 940 0 360 
13:53:45.443 -> 0 2596 1 976 0 356 1 388 0 356 1 944 0 360 1 940 0 360 1 384 0 360 1 944 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 388 0 356 1 944 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 356 1 16172 0 2008 1 923760 0 2596 1 972 0 360 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 356 1 944 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 944 0 356 1 944 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 360 1 940 0 360 1 384 0 360 1 940 0 360 1 388 0 360 1 384 0 360 1 384 0 360 1 944 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 944 0 356 1 944 0 356 
13:53:47.491 -> 0 2592 1 976 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 384 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 360 1 384 0 360 1 940 0 360 1 388 0 372 1 944 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 944 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 940 0 360 1 944 0 356 1 388 0 360 1 16168 0 2004 1 927984 0 2592 1 976 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 356 1 944 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 944 0 356 1 944 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 940 0 360 1 388 0 356 1 944 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 940 0 360 1 940 0 360 
13:53:49.541 -> 0 2596 1 976 0 356 1 388 0 356 1 944 0 360 1 940 0 360 1 388 0 356 1 944 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 940 0 360 1 388 0 356 1 944 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 944 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 944 0 356 1 944 0 356 1 392 0 356 1 16172 0 2008 1 927924 0 2596 1 976 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 356 1 944 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 944 0 356 1 944 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 944 0 356 1 388 0 356 1 944 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 944 0 356 1 944 0 360 
13:53:51.607 -> 0 2596 1 972 0 360 1 388 0 356 1 944 0 356 1 944 0 360 1 384 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 944 0 356 1 944 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 944 0 360 1 384 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 944 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 940 0 360 1 944 0 356 1 392 0 356 1 16172 0 2008 1 927440 0 2592 1 976 0 360 1 384 0 360 1 944 0 356 1 944 0 356 1 388 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 940 0 360 1 944 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 392 0 356 1 384 0 360 1 948 0 352 1 388 0 356 1 944 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 372 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 944 0 356 1 944 0 360 
13:53:53.644 -> 0 2592 1 976 0 360 1 388 0 356 1 944 0 360 1 940 0 360 1 388 0 356 1 944 0 360 1 384 0 360 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 944 0 356 1 392 0 368 1 944 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 360 1 16168 0 2008 1 927908 0 2592 1 976 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 356 1 944 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 940 0 360 1 940 0 360 1 388 0 360 1 384 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 940 0 360 1 388 0 356 1 944 0 360 1 384 0 360 1 388 0 356 1 388 0 356 1 944 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 384 0 360 1 388 0 356 1 388 0 360 1 388 0 356 1 944 0 356 1 944 0 356 

Ones are about 940 usecs...
By looking at columns i see that the protocol is no f*cking precise at all.

This is what i took from my "Daichi" 3rd party cloud controller; the only thing i personally have on hands. That's where i took 900 us from:

0 2604 1 1000 0 300 1 900 0 300 1 900 0 300 1 400 0 304 1 396 0 304 1 400 0 304 1 896 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 896 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 900 0 300 1 900 0 300 1 900 0 300 1 900 0 300 1 971340 0 2604 1 1000 0 300 1 900 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 396 0 304 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 900 0 300 1 900 0 300 1 900 0 300 1 971024 0 2604 1 1000 0 300 1 900 0 300 1 900 0 300 1 400 
0 2600 1 1000 0 304 1 896 0 304 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 304 1 896 0 304 1 404 0 296 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 308 1 396 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 896 0 304 1 900 0 300 1 900 0 300 1 970372 0 2604 1 1000 0 300 1 900 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 900 0 300 1 900 0 300 1 900 0 300 1 970444 0 2604 1 1000 0 304 1 896 0 304 1 896 0 304 1 400 
0 2600 1 1000 0 300 1 900 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 900 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 900 0 300 1 900 0 300 1 900 0 300 1 970996 0 2604 1 1000 0 300 1 900 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 900 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 900 0 300 1 900 0 300 1 900 0 304 1 971412 0 2604 1 1000 0 300 1 900 0 304 1 896 0 304 1 400 
0 2600 1 1000 0 304 1 900 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 896 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 900 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 900 0 300 1 900 0 300 1 900 0 300 1 970852 0 2604 1 1000 0 300 1 900 0 300 1 900 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 900 0 300 1 900 0 300 1 900 0 300 1 972964 0 2604 1 1000 0 300 1 900 0 304 1 896 0 304 1 400 
0 2604 1 1000 0 304 1 900 0 300 1 896 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 300 1 900 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 900 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 896 0 304 1 896 0 304 1 896 0 304 1 900 0 300 1 971028
0 2604 1 1000 0 300 1 900 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 896 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 900 0 300 1 900 0 300 1 400 0 304 1 400 0 304 1 396 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 304 1 396 0 304 1 400 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 400 0 300 1 400 0 304 1 396 0 304 1 900 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 400 0 304 1 400 0 300 1 400 0 300 1 900 0 300 1 900 0 304 1 896 0 304 1 896 0 304 1 971092

We clearly see there's no "DELAY END" sequence here.

This all completelly baffling. It seems that the protocol is actually super-tolerant. Damn, i have no idea why our tx doesn't work. Especially knowing, that tx code in my Arduino bridge DOES work, two people have confirmed that.

There aren't many variables here, really. We are just totally blind... We miss a ve-e-e-e-ry tiny detail.

Unfortunately Glinka has stopped giving me feedbacks, and i have nobody else to test with, I intentionally don't copy everything you're doing because it makes much more sense to try different things.

Also i would suggest to ignore new packet types for now. I think that perhaps they have come to the same conclusion as we did: not reporting actual state sucks; and checksum algo is LOL. They tried to fix this by extending the protocol in backwards compatible manner.

As to unknown bytes [1] and [2]; there definitely should be some capability flags. The AC must have way to indicate which optional features it supports (like H/V swing, LED control, etc). These flags must come with packet type 0, because that's the only data sent regularly. We can try correlating data in those packets to AC models and features they have. But that's low priority; we need to beat tx. We're definitely doin' it wrong(tm); and this wrongness is damn simple.

@Sonic-Amiga
Copy link
Contributor

Sonic-Amiga commented Feb 15, 2024

By the way, those who aren't afraid of Arduinos, can do two-way dump right now:

  1. Download code from my repo. The sketch you need is in Tools/Simulators/CN_WIRED/bridge
  2. Uncomment "#define RX2_PIN 3"
  3. If you want to get raw timings dump, uncomment also "#define DUMP_TIMINGS"
  4. Wire pin 2 to one line and pin 3 to another. Just in parallel with the wall panel. Yes, you need 5V arduino.
  5. Flash the sketch in, obviously
  6. Open serial port monitor in Arduino IDE, or any standalone terminal app on Arduino's COM port
  7. Watch the logs coming. It will look something like this:
Rx1 80 24 04 50 00 00 00 10 00 OK
Rx2 80 21 00 23 18 08 00 10 A0 OK
Rx1 80 24 04 50 00 00 00 10 00 OK
Rx2 80 21 00 23 18 08 00 10 A0 OK
Rx1 80 24 04 50 00 00 00 10 00 OK
Rx2 80 21 00 23 08 08 00 10 90 OK

Note this is an old dump; newer version will add microsecond timestamp to each packet, so that they can be correlated in time. Timings, if enabled, will look like long string of numbers. Something like:

Rx1 T 2600 1000 300 400 300 400 300 900 ...

(this isn't a real example, i made it up because i only used it to calibrate my own ESP8266 tx routine, and never saved such logs)

@revk
Copy link
Owner Author

revk commented Feb 16, 2024

I could perhaps be electrical?

Does anyone using a Faikin board on CN_WIRED have an oscilloscope they can use to check Tx?

The board was designed for serial, where the Daikin has internal pull ups, so is driven open drain. But if there is not a pull up, then we need to ensure the 5V is connected to there Faikin board to pull up.

@Sonic-Amiga
Copy link
Contributor

Sonic-Amiga commented Feb 16, 2024

@revk Good thing to check. You may look at schematic of "Daichi" controller in my repo under Hardware/; maybe this will give you some hints. I agree that Tx circuit looks weird; but i rechecked 10 times; Q1 indeed goes to Vcc, and R2 indeed goes to Vio, which looks like +5V. I have no idea how the line is brought down. Perhaps i guessed Q1 wrong; the transistor is unmarked, i simply tried to pick by footprint something that made the most sense.

Maybe that gives you some ideas. Anyways, this circuit does have pullups.

@revk
Copy link
Owner Author

revk commented Feb 17, 2024

Well it also depends if the 5V has been connected to the Faikin. A scope on the Tx would help.

@Sonic-Amiga
Copy link
Contributor

!!! BREAKING NEWS !!! IT WORKS !!!
Glinka65 has found a blown FET on his ESP8266 board. After replacing it everything works like a charm!

https://github.com/Sonic-Amiga/ESP8266-Faikin commit 6e7f267 - this is known working version

@revk If you do everything exactly the same way; the only possible problems are indeed electrical.

I will continue trying to improve the implementation; disabling interrupts on a running OS feels very harsh; But, anyways, we've got known working implementation.

@revk
Copy link
Owner Author

revk commented Feb 20, 2024

It would help to know if existing testers have 5V connected, and if any have a scope.

@adamsguitar
Copy link

It would help to know if existing testers have 5V connected, and if any have a scope.

I have 5v connected but do not have a scope, unfortunately. I can say that receiving does seem to work (though it does not seem like the mode is necessarily accurately reflected--I have mine running on Auto (not Faikin auto) and it's showing set as cool, but I'm looking at it right now and it's heating.

Happy to connect it to another MQTT server if it's helpful for debugging.

@revk
Copy link
Owner Author

revk commented Feb 21, 2024

Well, connecting to testmqtt.revk.uk would allow me to see it, but I think we need to confirm the electrical connection somehow. Glad you have the 5V connected, that really should work then.

@adamsguitar
Copy link

Well, connecting to testmqtt.revk.uk would allow me to see it, but I think we need to confirm the electrical connection somehow. Glad you have the 5V connected, that really should work then.

I assume not, but anything I could do with a standard multimeter to help?

@revk
Copy link
Owner Author

revk commented Feb 21, 2024

I doubt it, it works some times, so likely signal timing with the 10k pull up not being enough or some such.

@Sonic-Amiga
Copy link
Contributor

Sonic-Amiga commented Feb 22, 2024 via email

@revk
Copy link
Owner Author

revk commented Feb 23, 2024

My code does the 16ms high, 2ms low, at the end, already. Hmm.

@Sonic-Amiga
Copy link
Contributor

And you also have a 10K pullup; totally the same as Daichi board has...
Next week i am leaving for vacation; will be back on 16th of March. I checked ESP32 prices; i can buy a Pico devboard and do some testing with the gear i have (simulator and Arduino bridge). You really seem doing everything correctly; there's a very small thing somewhere.

@Sonic-Amiga
Copy link
Contributor

So, i switched TX back to timer interrupts; and it all works fine. The only thing i had to keep is 16ms high, 2ms low termination sequence.
I guess Daichi does not do this, but still works because it repeats the packet 6 times; and 2500ms start of the repeated packet is somehow taken by the AC as end pulse. Pause between repeats is 16ms; it matches. That's just for info. As i said, my implementation doesn't repeat; it just sends once. Glinka65 says it works great.

@Sonic-Amiga
Copy link
Contributor

Updated the protocol doc. Please pay attention to swing control details; appears quirky.

@revk
Copy link
Owner Author

revk commented Feb 27, 2024

@Sonic-Amiga
Copy link
Contributor

Hello guys!
I am here, it's all OK, i am silent because i am busy preparing for the vacation. Leaving for Thailand, will come back on 16th. After this, if you don't fix things by yourself, i'll buy a ESP32 Pico board and try playing with this myself.

@type-rke
Copy link

type-rke commented May 5, 2024

is this still on thé table?

@revk
Copy link
Owner Author

revk commented May 5, 2024

We got a bit stuck really.

Recreating the protocol, but seems not to play.

We can receive.

@Sonic-Amiga
Copy link
Contributor

Sonic-Amiga commented May 5, 2024

We are assuming there's an electrical incompatibility in Faikin board. And i've got an idea how to verify this.

My ESP8266 port works great on its original target HW; my user Glinka65 is happy. So, what if we take a Faikin board and transplant a 8266 module onto it ? My board is built around ESP-12F; so that's just 100% known to work. Flash with my firmware and try. If the issue persists; it's indeed electrical problem. If not - the code is broken and we're missing something out; just look real carefully.

Yes, requires electronics skills.

Also i have recently purchased an ESP-32S-based devboard; so i'll be able to play with the firmware on my side. But i don't have an actual A/C; only a simulator; and Glinka doesn't live in my city so we can't meet up for hands-on testing.

Sorry for my own disappearance. I was attacked by sheer laziness after the vacation.

@revk
Copy link
Owner Author

revk commented May 6, 2024

Equally my code on a board with 5V level shifters may work.

@Sonic-Amiga
Copy link
Contributor

Looked at Faikin schematic once again... Indeed, it's possible that pull-up on TX line (from Faikin to AC) is missing. And the fix could be as simple as connecting pins 1 and 4 of Faikin connector together.

!!! Before doing this, make sure that power supply voltage from the AC is 5V and no more !!!

@lank23
Copy link

lank23 commented Jun 23, 2024

Evening all.

specs
indoor unit = FTXB18AXVJU
device = HiLetgo ESP-WROOM-32 ESP32 ESP-32D

I have a unit that only has CN-WIRE connection. I made a cable using info found on this site and connected up the ESP32 device. Erasing then Flashing the ESP32 device with the latest beta or main release firmware using the below commands allowed the unit two boot and operate correctly.

esptool.py erase_flash

then

esptool.py --port /dev/ttyUSB0 write_flash 0x1000 Faikin-S1-bootloader.bin 0x8000 partition-table.bin 0xd000 ota_data_initial.bin 0x10000 Faikin-S1.bin

After I configured the TX and RX GPIO to TX = 1 and RX = 3. Then I set the settings to only use CN-WIRE but I continue to have offline message on the web interface. But when I use the remote to change any setting the web page is updated in real time.

I hooked my oscilloscope up to TX pin of the ESP32 and I get nothing when changing settings on the webpage or operating the remote. Tried a 10k pull up on TX pin, still nothing....I have tried changing many settings and different GPIO pins (some prevented boot) but still nothing makes the TX pin work! If I connect my oscilloscope to the RX pin I get output from the unit every second and when using the remote.

So why do I get nothing on TX pin and the web page shows offline?

Thanks.

@revk
Copy link
Owner Author

revk commented Jun 23, 2024

I am not sure we finally crasked it, but you should see data sent!

@lank23
Copy link

lank23 commented Jun 23, 2024

Ok so I figured maybe my esp32 device was bad or non compatible in some way, so I switched to a ESP8286 device "ESP8266 ESP-12 ESP-12F NodeMcu Mini D1 Module WeMos Lua 4M Bytes" and uploaded branched firmware from here set TX = 1 RX = 3, selected only CN-WIRE for protocol and it is working! So not sure if its the hardware or the firmware...Thanks

Edit to add the programming commands

esptool.py erase_flash

esptool.py --port /dev/ttyUSB0 write_flash 0x0 Faikin-8266-bootloader.bin 0x8000 partition-table.bin 0xd000 ota_data_initial.bin 0x10000 Faikin-8266.bin

@Sonic-Amiga
Copy link
Contributor

Small note. My port ignores rx/tx pin setting; those are hardcoded to 3 and 1 because that's the only valid choice. In 8266 they aren't reprogrammable.

@Sonic-Amiga
Copy link
Contributor

Sonic-Amiga commented Jun 23, 2024

@lank23 Can you describe your HW setup more precisely ? Have you taken your Faikin board and transplanted a 12F onto it; or have you done something else ?

"Offline" means you aren't receiving any data. CN-WIRED ACs don't need to be actively queried, they just send status once per second. So you should at least see data coming from the AC, and the controller should be able to decode and display current status once you control the conditioner using its remote.

Nice to hear that my port works for someone else, however

@revk
Copy link
Owner Author

revk commented Aug 18, 2024

I have boards coming to test with a pull up on the Rx side, if someone with CN_WIRED is in UK I could send a sample.

@ghpazo
Copy link

ghpazo commented Nov 2, 2024

Hi, a have succesfully tested ESP8266-Faikin on FTXN25JXV1G units equipped with cn_wire connector. The 5-pin connector pinout is 12VRxGndTx5V. I have also tested the sleep mode available in this units. This mode is entered sending the special mode 0x20. Maybe this mode can be included in future releases.

@revk
Copy link
Owner Author

revk commented Nov 2, 2024

Interesting.

@Sonic-Amiga
Copy link
Contributor

Hi! I have just returned from vacation, hope get my hands back on project this weekend. I will add support.
What does sleep mode do by the way?

@Sonic-Amiga
Copy link
Contributor

@revk i guess you can default this protocol as "enabled" on Faikin32
During my vacation i actually tried to acquire an original wired panel for this, but it was out of stock:(

@ghpazo
Copy link

ghpazo commented Nov 2, 2024

Acording to the user manual sleep mode does:

  • When the unit is operating under cooling mode, the set temperature is increased by 0.5°C after the first half an hour, another 0.5°C after the second half an hour and 1°C after the following 1 hour.
    • When the unit is operating under heating mode, the set temperature is decreased by 1°C after the first half an hour, another 1°C after the second half an hour and 1°C after the following 1 hour.
    • This function is available under COOL, - HEAT and AUTO mode.

@Sonic-Amiga
Copy link
Contributor

Aha, i know this function; seems all those units have it.
Under "special mode" you mean byte 5 (CNW_SPECIALS_OFFSET), is that correct ?

@ghpazo
Copy link

ghpazo commented Nov 6, 2024

That's correct, I added:

#define CNW_SLEEP 0x20

In cn_wired.h

and

if (daikin.sleep)
specials |= CNW_SLEEP;

In Faikin.c., line 864

By the way, for the comments on CNW_V_SWING near line 858, I can confirm that it works on my unit.

@Sonic-Amiga
Copy link
Contributor

So do you already have a patch?

@ghpazo
Copy link

ghpazo commented Nov 6, 2024

Yes! Please tell me how I can provide it!

@Sonic-Amiga
Copy link
Contributor

From your question i conclude you have never forked projects and published PRs. In fact that's easy:

  1. Fork the project
  2. Implement your feature
  3. Push into a branch (you could push on main, but that could create problems syncing back)
  4. Follow a link provided by GitHub to create a PR
  5. I review and merge

If you find this difficult for whatever reason, you can simply attach output of 'git diff', i will apply that

@ghpazo
Copy link

ghpazo commented Nov 6, 2024

You are right, i've never published PR :)

I' ve followed your indications and I think i'ts done.

@Sonic-Amiga
Copy link
Contributor

@ghpazo Hi! Sorry for my silence, too much stuff to do plus quite difficult re-acclimatization back from +28 to 0C :( I am too sleepy...
I've seen the PR, thank you very much for contribution. I'll redo it a bit, however. I think it's an overkill to introduce yet another switch for this function; because we already have "comfort" switch, which is apparently never present on those A/Cs. So i think about reusing it.

@revk WDYT ?

@revk
Copy link
Owner Author

revk commented Nov 12, 2024

Whatever people think best

@Sonic-Amiga
Copy link
Contributor

@ghpazo Hello! Thank you very much for your contribution! I thought for some more, and merged your patch as it was. After all, "Sleep mode" and "Comfort mode" are very different functions.

I only adjusted value for VSwing from 0x70 to 0x50, so that it doesn't clash with the newly discovered bit. I released a beta, you can find it in the repo or download it from my second update server: http://faikin-ota.home-assistant.my/ . Please check.

By the way, for the comments on CNW_V_SWING near line 858, I can confirm that it works on my unit.

What exactly works? Swing mode ? It should, because we figured it out with Glinka65, my first user who kickstarted CN_WIRED effort and helped with reverse engineering electrical part.

You know what, if you are coding, could you help figure out, which of remaining two bits actually enables swing ? 0x10 did not work with Glinka, so we simply left it as 0xF0 back then (there was no LED control yet). Note also buf[6] in daikin_cn_wired_send_modes()

The behavior currently implemented was copied from 3rd party "Daichi" controller; that's the only reference i had.

Maybe you have some original Daikin equipment, which plugs into this port, like wired wall control panel ?

@Sonic-Amiga
Copy link
Contributor

And sorry for terrible delay; i lost my sleep, no idea why, just seem to more or less recover.

@ghpazo
Copy link

ghpazo commented Nov 28, 2024

Hi, I'm sorry for the delay, I've been out for a couple of days.

I've tested the beta and it worked fine.

I don't have a daikin controller which plugs into that port, all the info I could get is analyzing the unit response to commands sent by the ir controller. I've tried setting the on, off timers, triggering an error, diagnostic mode, etc but that info seems no to be sent to the cn_wired port.

As for the swing mode, I've done some tests and on my unit the only bit that enables it, is bit 0 of 6th byte. Changing the other bits in CNW_SPECIALS_OFFSET doesen't seem to change swing mode or any other visible features.

Acording to the IR remote user manual, some units have 3 swing modes, full, upper and lower, maybe the other bits control that.

Please let me know if you want me to do more tests.

@mikelawrence
Copy link

I've been recently testing a Faikin connected to CN_WIRED on my Diakin FTXB12AXVJU Mini Split. Seems to be working just fine. Thanks for all the hard work!

However it was a challenge to figure out the wiring for this connector since it is not listed on the main documentation. I was wondering if CN_WIRED support is considered stable enough to document it on the Wiring page. There are also no models listed on the List of confirmed working air con units that mention the CN_WIRED connector. I would be willing to make these changes if you agree.

@revk
Copy link
Owner Author

revk commented Dec 1, 2024

To be honest, you are in the best position to say if it works, as I have no CN_WIRED devices.

Happy for a pull request or just suggestions for adding to wiring page.

@Sonic-Amiga
Copy link
Contributor

@mikelawrence Hello! I guess it's stable, just it appears to be quite rare, we don't have many users.
@ghpazo Thank you for testing, i'll update documentation and comments in the code. If your RC doesn't have any other functions, not covered by the current implementation, i guess we have nothing more to test.

@mikelawrence
Copy link

@revk I'm not a strong GIT user and forking Faikin does not include the Wiki so I couldn't use a PR, but Github allowed web based Wiki modification. So that's what I did on the Wiki Wiring page. If I have overstepped my bounds or breached etiquette by all means scrap the changes.

@err53
Copy link

err53 commented Dec 16, 2024

Hey all, I got my minisplit with CN_WIRED working. I noticed that the internal temperature sensor readout is displayed incorrectly at low temperatures. Specifically, anything below 8 degrees C overflows to 162 degrees C.

image
image

If you need data dumps do let me know, and I'll see what I can do.

@revk
Copy link
Owner Author

revk commented Dec 17, 2024

OK, not 100% sure what debug you can get, but if you can try we may see the messages. It is a decode of BCD which should be simple.

@Sonic-Amiga
Copy link
Contributor

Hello!
Please activate 'dump', read 'tx'/'rx' log over mqtt and post here. I have an impression that some specific encoding is used for negative values. Doh, man, that's internal temp; are you Santa Claus ? :)

@err53
Copy link

err53 commented Dec 17, 2024

Will do! It warmed up a bit recently, so I'll post the dump once the temperatures fall again. (The minisplit's in an apartment thats only occasionally used, so we keep it unheated) :P

@err53
Copy link

err53 commented Dec 22, 2024

Alright, I've got some readings I pulled from MQTT:

Here's a few for when it's displaying "underflow" temperatures

Topic: info/apartment-daikin/rx
{"protocol":"CN_WIRED","data":"FC04500000000040","rmt_rx_len":66,"sync":2604,"start":1003,"space":301,"0":402,"1":1015}
{"protocol":"CN_WIRED","data":"FC04500000000040","rmt_rx_len":66,"sync":2605,"start":1002,"space":298,"0":404,"1":1021}
{"protocol":"CN_WIRED","data":"FC04500000000040","rmt_rx_len":66,"sync":2606,"start":1002,"space":299,"0":405,"1":1011}
{"protocol":"CN_WIRED","data":"FC04500000000040","rmt_rx_len":66,"sync":2606,"start":1002,"space":299,"0":404,"1":1020}
{"protocol":"CN_WIRED","data":"FC04500000000040","rmt_rx_len":66,"sync":2606,"start":1003,"space":301,"0":402,"1":1015}

This with the minisplit off:
{"ts":"2024-12-21T23:49:00Z","id":"F412FA97D4D8","up":true,"uptime":246160,"mqtt-up":246150,"app":"Faikin","version":"9f65e5b","build-suffix":"-S3-MINI-N4-R2","build":"2024-11-30T08:32:55","flash":4194304,"rst":3,"mem":109624,"spi":2091968,"ssid":"*****","bssid":"*****","rssi":-80,"chan":6,"ipv4":"*****","ipv6":"*****","online":true,"power":false,"target":20.00,"temp":162.00,"mode":"off","fan":"auto","powerful":false,"swing":"off","preset":"home"}


And here's a few displaying temperatures at 8 degrees C:

Topic: info/apartment-daikin/rx
{"protocol":"CN_WIRED","data":"0804500000000010","rmt_rx_len":66,"sync":2606,"start":1002,"space":303,"0":402,"1":1001}
{"protocol":"CN_WIRED","data":"0804500000000010","rmt_rx_len":66,"sync":2606,"start":1001,"space":306,"0":399,"1":1001}
{"protocol":"CN_WIRED","data":"0804500000000010","rmt_rx_len":66,"sync":2605,"start":1002,"space":307,"0":399,"1":991}
{"protocol":"CN_WIRED","data":"0804500000000010","rmt_rx_len":66,"sync":2605,"start":1003,"space":306,"0":399,"1":1001}
{"protocol":"CN_WIRED","data":"0804500000000010","rmt_rx_len":66,"sync":2606,"start":1001,"space":301,"0":404,"1":1001}

Also with the minisplit off:
{"ts":"2024-12-21T23:54:07Z","id":"F412FA97D4D8","up":true,"uptime":246467,"mqtt-up":246457,"app":"Faikin","version":"9f65e5b","build-suffix":"-S3-MINI-N4-R2","build":"2024-11-30T08:32:55","flash":4194304,"rst":3,"mem":109836,"spi":2091968,"ssid":"*****","bssid":"*****","rssi":-80,"chan":6,"ipv4":"*****","ipv6":"*****","online":true,"power":false,"target":20.00,"temp":8.00,"mode":"off","fan":"auto","powerful":false,"swing":"off","preset":"home"}

Let me know if I grabbed the data incorrectly or if there's anything else I can do to try to help 😅


EDIT: Unrelated, but it looks like controlling the unit still doesn't work properly for me, could the older board revision be at fault? I recall some discussion about a pull-up resistor...

@Sonic-Amiga
Copy link
Contributor

{"protocol":"CN_WIRED","data":"FC04500000000040

Hm, very interesting. Yes, it's proper data. Looks like 2-complement; 0xFC standing for -4. Do you have any other thermometer at home to confirm the value ?

And does this value change over time ? I. e. when you start heating up the room.

Could be just some sort of "underflow" indicator because i'm not sure if Daikin would seriously consider negative indoors temperatures. In their place i'd just say those are off-limits, and your house is probably in trouble.

@err53
Copy link

err53 commented Dec 22, 2024

It looks like it stays at that value no matter how the temperature changes while < 8 degrees C, and starts behaving normally again as soon as it gets to >= 8 degrees C. Yeah, I would assume it's most likely a constant "low temperature" flag for temperatures it thinks is too low to bother displaying.

@revk
Copy link
Owner Author

revk commented Dec 23, 2024

Sonic, I would suggest we do handle negative, but we have to work out how they code them. I agree, it sounds like -4.

@Sonic-Amiga
Copy link
Contributor

So far @err53 said the reported value doesn't change any more. So my current guess is that this particular byte stands for "too low, out of range".
I would suggest to either promote it to 0 (so that graphing looks sensible), or report something like "<=0" in the web UI, but still promote to zero for mqtt listeners for the said reason. Any other values, which don't look valid BCD, could be reported as they are, so that we could catch them if ever seen. @revk WDYT ?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

9 participants