-
-
Notifications
You must be signed in to change notification settings - Fork 67
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
Support for RTL8710CM? #44
Comments
anything we can do to push support forward? idk what's missing/required :( |
Not really, unless you either know C/C++ well and are comfortable working in crappy vendor SDKs, or can buy me more time 😄 |
I've successfully compiled and ran the PinScan example (amazingly helpful, btw!) and flashed libretiny-esphome on a RTL8710CM with your recent changes. Everything I was able to test seems to work using the It seems compiling a project with PlatformIO and/or libretiny doesn't pull in the |
RTL8720C only has very draft support. Some people (incl. me) have reported ESPHome to work, but not stable. OTA is implemented for Beken and RTL8710B - only RTLC doesn't support it at present. The AT CLI is a default "demo" application of the SDK - it isn't (and won't be) available in LibreTiny. The built-in OTA functionality is very basic and also will not be supported. Instead, UF2 OTA will be implemented (at some point...), just like on Beken and the other Realtek. This is a universal and safe format that we're using for everything in LibreTiny. Download mode hasn't been documented yet (as in: very draft support), but can be activated by pulling PA0 and PA13 to 3.3V, and resetting the chip/power cycling while doing that. It takes a few attempts to do so, but gets easy after you get it. Note: after you first flash LT, download mode can be entered automatically (or by sending As for the BL0937, see https://upk.libretiny.eu/ - find a plug with power monitoring, generate a YAML for it, and see which pins usually need the |
Thanks for the information! Yes, I realized support for the RTL8720C family is in the very early stages. Just figured I'd report my findings. That makes sense regarding the AT CLI. Since the stock TP-Link EP25 had it I assumed it was standard and always built w/ the RTL MCUs. Their firmware must be based off the "demo" (which makes sense, I guess). A quick perusal through their stock firmware revealed that there seems to be a way to trigger the SDK-included OTA function remotely. It may be possible replace the stock firmware on these smart plugs wirelessly without opening them up! 😎 I'll poke around some more with download mode. I've tried |
Eventually OTA will be supported. Have you dumped the original firmware prior to flashing? If yes, you can always mess with it by just flashing it back. |
As indicated in this thread (and in LibreTiny docs -> boards, chips, features) RTL8720C is not yet fully supported. Thus, the documentation pages are also not fully written. |
Kinda why I was asking here ;-) I'm an out of practice embedded C/C++ developer who is willing to have a play with it, but thought rather than re-doing work that's already been done I'd ask the question. |
I was playing with a Tuya WBR3-laden ME81H (thermostat for a heater). I see above documentation that I found from this page during my trials: https://developer.tuya.com/en/docs/iot/burn-and-authorize-wbr-series-modules?id=Ka78imt8pf85p#title-7-Method%202%3A%20Separated%20solutions%20for%20flashing%20and%20authorization After fixing up
Comparing the dumped images, it seems the initial (and trailing?) portions of Flash are the same; I see "hash" related strings at the same offsets (I have not poked with Ghidra yet, lacking the time currently). I wonder if using the Tuya "RTL8720CF chip burning tool" would program the correct hash, or if this has been reversed yet?
Anyway, it seems I'm at a dead end with this board, and support is in progress, so kudos for everything so far and in the works. In the mean time, I've ordered an ESP32-C3-12F module to replace this unit (which seems to operate fine without the Tuya module installed, in case anyone needed to know). As such, let me know if there's anything I can test or help reverse to support the Tuya WBR3/RTL8720CF. |
@nmschulte |
|
This firmware uses OTA1 address of 0x10000, while the board you've chosen has it at 0xC000 - it's incompatible with WBR3. As you've noticed, support is in progress. The WBR3 board (with correct offsets) is available in That being said, when RTL8720CF support rolls out, it will automatically adjust flash addresses to match the chosen board code (same will be done for RTL8710BN shortly). |
You rock. I'll give it a whirl. |
Success!
WiFi shortly there-after disassociated but subsequently reconnected:
And later, after another (minutes after) diss-/re-assoc; perhaps this is expected, as I'm unfamiliar w/ ESPHome and didn't do anything but let the code run:
|
Initially, I hacked my way through this, unaware that I could specify these things in the device YAML; I rtl87xx:
board: wbr3
framework:
version: 0.0.0
source: https://github.com/libretiny-eu/libretiny.git#feature/realtek-updates Mainly,
It seems the trend is to use a I guess |
Also, it seems the firmware insists on outputting to UART2 (LOG_TX / LOG_RX), messages from WiFi driver: As well, I can't seem to configure ESPHome to output on the other exposed UART (TXD / RXD; 13 and 14 I believe). This is stumping me. |
After modifying |
UART2 is the default port for log messages, same applies for Tuya firmware. Why did you need to change it, and how did you try to do so? PS I notice that |
I didn't need to change the logging UART. Though, because I was unable to use the other UARTS (HW_UART1 and HW_UART2, because the hardcoded checks against Then, I noticed in the debug output that the UART0 and UART1 RX/TX pins were outputting as diff --git a/boards/variants/wbr3.h b/boards/variants/wbr3.h
index 40f6595..d40a1d5 100644
--- a/boards/variants/wbr3.h
+++ b/boards/variants/wbr3.h
@@ -28,8 +28,10 @@
// ------------
#define PIN_SERIAL0_RX_0 12u // PIN_A12
#define PIN_SERIAL0_RX_1 13u // PIN_A13
+#define PIN_SERIAL0_RX 13u // PIN_A13
#define PIN_SERIAL0_TX_0 11u // PIN_A11
#define PIN_SERIAL0_TX_1 14u // PIN_A14
+#define PIN_SERIAL0_TX 14u // PIN_A14
#define PIN_SERIAL1_CTS 4u // PIN_A4
#define PIN_SERIAL1_RX_0 2u // PIN_A2
#define PIN_SERIAL1_RX_1 0u // PIN_A0
The build is already proceeding w/ these defines, yet the WiFi output still persists. This is not an issue though as it's on the logging UART: |
Hi @nmschulte just wondering how stable is LT running on the thermostat since? |
Did you ever resolve this? I am seeing the same problem. And this is the topic was the only result googling for it. |
Hello, Unfortunately, I can't find this chip layout at: But it is RTL8720CF. I will patiently wait for updates. Thank you for all your work. |
Just wanted to share that after traveling down miles of rabbit-holes, I came to the unusual discovery that RTL8710CF (which I want to point out is slightly different chip ID from the OP's RTL8710CM, and also different from RTL8720CF that was discussed later -- if there's no meaningful difference in the hardware, apologies for the noise) can actually be compiled & successfully flashed with the following ESPHome yaml snippet: rtl87xx:
board: wbr3
family: rtl8720c
framework:
version: 0.0.0
source: https://github.com/libretiny-eu/libretiny#feature/realtek-update FWIW, my RTL8710CF was found inside a Kasa HS200(US) hardware v5 (e.g. the smaller one compared to some of the earlier HS200's, I haven't opened one of those yet to see what's inside). Initially, having read this and other issues plus the LibreTiny documentation discussing the Ameba chip nomenclature, I didn't actually realize I had an RTL8710CF and not an RTL8720CF or RTL8710CM. |
Oh, interesting. Thank you for the heads-up, @k-w-1! I guess I can re-add the M515EGWT blinds I once bought (with a wbr3 chipset) into my queue :) (pointing the other threads here accordingly) |
The RTL8710/8720/CM/CF chips are similar and compatible. The difference between 8710 and 8720 is Bluetooth support in 8720. The difference between CN and CF is memory, CF having built-in flash memory, CM having built-in PSRAM. Keep in mind that while ESPHome works on these chips, certain features are not supported and the firmware might be unstable. A notable example of such features is OTA updating. |
Thank you very much for the detailed information, @kuba2k2! |
This is very timely news indeed, since I have just popped open my Kasa EP10 smart plug and discovered it has an RTL8710CF in it! |
Has anyone found a proper pinout for such a chip/board yet? |
I have opened and measured my Here is what I found out:
If someone might be able to assist me in converting this to a configuration and tell me how to flash it to the chip I'd appreciate the help. I have a BW15-Kit with the same IC but was not able to successfully flash anything to it yet with ltchiptool (not completing the flash) and flashing with the Realtek AmebaZ2 PG Tool (v1.2.47) just led to invalid RAM signature errors on the serial output from the bootloader. |
Hi @ThxAndBye, you must've been reading my mind, because I also started tinkering with P100 EU this weekend to control some Christmas lights. If I had your message, I wouldn't have to desolder the board, because I traced the same pinout as you, so nice job! After some picking and prodding I managed to get LibreTiny and ESPHome to work on this board including OTA. I found two bugs in the flashing code, which prevented the bootloader and partition table from flashing and caused a hash error. I fixed those and hacked together OTA support, because the P100 is difficult to open. Here are the instructions to flash ESPHome onto the P100: 0. Install python3 -m venv tapo-p100
. tapo-p100/bin/activate
pip install git+https://github.com/prokoma/ltchiptool.git@ambz2-fix
ltchiptool -V 1. Open the device. I used some old plastic cards to pry the side wall away from the device. There are two clips on each of the 4 sides, when you get an opening, stick a piece of the card in so it doesn't close again when you work on the other side. Start on the side with the button first, because it is the weakest. Do not use anything metal, because you could scratch or knock some components off the board, there are tiny resistors and traces near the edge. 2. Connect a 3.3V UART interface to the test points. RX to TX1, TX to RX1, V3.3, GND, everything is marked on the board. Also hook a wire to GPIO0, which is used to enter the bootloader. Be 100% sure that your UART converter doesn't output 5V on the VCC, some cheap ones do and will fry the chip. You can check with your multimeter before connecting it to the board. GPIO0 has to be pulled to 3.3V before powering the chip to enter the bootloader. I first powered GPIO0 and then V33. 3. (optional, but recommended) Make a backup dump of the flash, so you can revert to the stock firmware. ltchiptool flash read -c realtek-ambz2 path/to/store/dump.bin 3. Build an ESPHome firmware and download the UF2 firmware file. You can use vanilla ESPHome, the magic is in the 4. Flash the firmware to the board using ltchiptool flash write path/to/firmware.uf2 5. The device should boot up. If you use my config, the orange led should light up for a few seconds while it is connecting to your wifi. Disconnect GPIO0 and try the OTA a few times before closing the device, because you don't want to open it twice. Report if there are any issues. |
This is a picture of my setup, I used some wires from an old IDE cable, because they are thin and easy to solder. And proof that it works and shows up in HA. Thank you again @kuba2k2 for your hard work on LibreTiny. |
Nice work! |
@prokoma Thank you for providing the detailed guide and configuration. I've been able to connect and read the flash of the controller but when compiling ESPHome I get an error when the UF2 is build:
I had no issue to build an image with the |
@ThxAndBye This error means that LibreTiny itself is from my branch, but the ltchiptool it imports is the original version. You can try to delete the |
@ThxAndBye I've changed the reference to use a specific commit hash of ltchiptool instead of branch name, that could also help. You also have to use a commit hash in the
|
@prokoma restarting the ESPHome Container in HA has helped as this cleared all the files. (Using "Clean Build Files" didn't help). I was able to compile the .uf2 and it's working on my P100. Thank you for your help and work in getting the RTL8720CF and Tapo P100 working with ESPHome. |
@prokoma I've gotten so far but I can't get a successful write. TPLink KP400 with RTL8710CF. I took the firmware dump, compiled a firmware, and trying to write back to the chip. I can get it to write up to about 5-10%, and then it fails. |
LMK, I can share my yaml, or uf2 file, or the commands I'm using, or the log output of the ltchiptool command |
@jpmiller25 The error you're having is a more low level one. I'd double check the power situation and connections. Check that the relay coils are not getting power (that could drop the voltage a fair amount) and that your 3.3V supply is outputting the correct voltage. Also don't use overly long wires for the connections and if you're using Chinese Dupont wires, check the connection between the wire and the connector, sometimes the wire is rotten at the ends and that causes high resistance. |
I have a Xiaomi smart humidifier. The product uses an mhcwb4p-b chip and has a core of RTL8720CN. I tried and failed to upload espome to this product. I'm not a programmer, so I leave it for recording. esphome yaml
When you upload espome firmware, it pops up in the debug log like this.
So I did a firmware analysis. Original
esphome
That's all I can do. Hope it helps someone walking down the same path. |
@plplaaa2 If it has RTL8720CN, my fork should work. The chip has no permanent security, if you can flash it via UART, it should work. But you'll probably lose updates for the second IO chip, if the miot custom components can't flash it. You need to use my fork of ltchiptool for flashing, see #44 (comment). Then you put this in your ESPHome config:
If you have issues, please share the entire ESPHome config with secrets removed. |
I've already used your config, but I haven't tried the ltchiptool as a fork version. I've already reassembled the device, so I'll try it next time I have time. Thank you.
|
@plplaaa2 Ok, that explains it. In the official ltchiptool, the first 512 bytes of the flash are skipped and that causes the signature error. |
@prokoma Thanks for your work! I managed to flash ESPHome to a Tapo L900 Led strip, still have to adjust few things but is working now. https://github.com/CladZo91/esphome-devices/blob/main/src/docs/devices/Tapo-L900-5EU/index.md |
Is there support for RTL8710CM yet?
I have a couple of devices (Tapo L920 LED controllers) using this chip and would love to be able to flash them with libretuya/esphome.
The text was updated successfully, but these errors were encountered: