-
Notifications
You must be signed in to change notification settings - Fork 33
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
porting firmware for TS0201 _TZ3000_v1w2k9dd #128
Comments
You first have to check if your board looks like https://pvvx.github.io/TS0201_TZ3000/. You need to check if LED and BUTTON are connected to the right ports of the ZTU also. If not, you can't use any prebuilt firmware and have to compile it yourself. Look at #124 |
@pvvx Tuya is obviously very messy so wondering if you can tell me if this variant is somehow already supported either by downloading an OTA binary or compile one myself? Thanks! |
I have the same boards as @dynasticorpheus and wanted to flash them with a new firmware to get configurable report intervals. The PCB traces as follows: I quickly had a look at https://github.com/pvvx/ZigbeeTLc where I saw that apprently the boards are defined in src/board_*.h. Cheers, |
I'm currently trying to port the firmware for software I2C and the CHT832x sensors. |
Alright. I couldn't wait for the programmer to get here so I fiddled around with the USB->UART SWire emulation and got a working firmware flashed. I will download the old firmware when I get the hardware programmer. @pvvx How would you like me to contribute this? Also I'd be interested in a way to forcefully flash the original Tuya devices with the new firmware without having to solder an SWire programmer to the board.
|
Full match with ZY-ZTH02Pro. But no LCD. The sensor is probably a clone of SHT30. https://www.gxcas.com/public/en/public/html/index.html#/proOne?pid=21&id=23 Already working in an unheated garage in "LE Long Range" mode: At that distance from home and with multiple walls, Zigbee doesn't work: https://github.com/pvvx/ATC_MiThermometer/raw/refs/heads/master/ZY02_v50.bin - Will work for your device temporarily. |
I recommend unsoldering or breaking out R13 and R11. This is unnecessary battery consumption and does not provide anything else.
|
Good stuff, mate. The sensor is definitely a CHT832x. If you are interested in my changes, I have just created a fork and uploaded my changes. Basically I created or changed the following files:
Makes sense by the way that these boards are similar or share the firmware. Do you know why R13 and R11 are there in the first place? Cheers, |
ADC divider for measuring battery voltage. |
id: 00308010 -> Status Register at startup: 0x8010. |
@dbmaxpayne Is this still WIP or can I have a go at it? ( |
@dynasticorpheus Let me know in a private message what error you're getting and I might be able to help. I will upload the bin files to my fork in a second if that helps. Edit: |
Hi there, many thanks for all your efforts. |
I'd be interested too if there is a way to flash this over a stock firmware via OTA. I used this: https://github.com/pvvx/TlsrComSwireWriter
|
@dbmaxpayne - what "Zigbee Image Type" does the original TS0201 _TZ3000_v1w2k9dd have? 1002-0203-59013001 ?
? |
@pvvx |
ZHA only gives this: 1002-0203-59013001 I got from the header of the firmware binary file.
https://github.com/pvvx/ATC_MiThermometer/tree/master/utils -> zigbee_ota.py fw 1002-0203-60993001-ZYZTH02BLE_v50.zigbee for converting Tuya Zigbee to BLE added to https://github.com/pvvx/ATC_MiThermometer I don't use Zigbee2MQTT and I can't say anything about it. |
Sorry, I only started with Zigbee last week when I got those sensors, so my learning curve is still quite steep. So I guess 1002 and 0203 are correct. I will try 1002-0203-60993001-ZYZTH02BLE_v50.zigbee on my second sensor once I downloaded its stock firmware. |
For your ts0201_tz3000_v1w2k9dd.bin file, create a header for Zigbee OTA:
It will be 1002-0203-60993001-ts0201_tz3000_v1w2k9dd.zigbee Zigbee OTA is triggered automatically if the program version number is higher. |
Thanks both for your inputs. I have an "Invalid Image" error from z2m ota update. It was so close ;-) but I am unsure how I can get the exact information |
@vjaunet |
That's the one I tried, obtained as per pvvx instructions from your bin file. |
@pvvx
Can or should they be removed when using your firmware to save power? |
GPIO_PB5 and GPIO_PC0 are not used. This does not increase battery consumption. |
A large increase in consumption is created by ZHA, forcing the "Long Poll interval" to 6 seconds. This is the notification time of the device that it is working. In the Zigbee 3.0 standard, the "Long Poll interval" is set within the limits that the device transmits. But ZHA does not look at what the device says. Have to write a patch into the firmware because of ZHA... And the firmware loses full compatibility with ZigBee 3.0. zha\zigbee\cluster_handlers\general.py (LONG_POLL = 6 * 4 # 6s)
For some reason, for IKEA devices, ZHA ignores the forced LONG_POLL setting of 6 seconds. CHECK_INTERVAL - after this interval, if the device has not notified, then it will be disconnected from the network. |
Any luck with applying OTA as soldering is out of my league unfortunately? |
That worked nicely, it was just missing the write address in the second command line :
Many thanks ! |
So my hardware programmer has finally arrived. I have tried to upgrade the firmware of my second device without soldering by changing the zigbee header using the command @pvvx mentioned: However, I also get an INVALID_IMAGE error. With my narrow understanding of the topic and using a hex editor I can see that the MANUFACTURER_ID and IMAGE_TYPE should be correct at addresses 0x12 and 0x14. Cheers, |
Here are the data obtained in the ZHA log about the firmware in the new https://pvvx.github.io/ZY-ZTH02/:
manufacturer_code=4098=0x1002, But, no matter what numbers I put in, ZHA complains during OTA: I tried to feed it my own original firmware. The result is the same. It seems that the original firmware does not support Zigbee OTA or has an error. It is also possible that some special registration is required from the manufacturer's device. |
So the most solderless version will probably be using Victor's https://github.com/pvvx/TLSRPGM repo. I used the following command to write the firmware:
If you have a USB->UART converter you can also try https://github.com/pvvx/TlsrComProg825x. |
Apparently, in this version of the original firmware, Zigbee OTA simply does not work. There are many things that point to this. The firmware does not support changing the communication interval, and in the analysis of the operation by current consumption, when turning on OTA, it simply breaks the connection, and when forced to start by short pressing the button, an error appears. Otherwise, OTA will be interrupted due to timeout at the initial 0.3%. |
I did give a comparison, but with BLE. |
I can't get my flashed Thermometer to join Zigbee2mqtt. Have you managed to get it to join ? Also, no led is working anymore on the thermometer, is that for energy saving purposes ? |
I have been delivered TS0201 _TZ3000_v1w2k9dd and try to get around. |
So something went wrong during the firmware. It's worth repeating. |
LED blinks only very shortly with my firmware. If that doesn't work I also recommend just flashing it again. |
@dbmaxpayne In your firmware, the LED always turns on when TLSR825x is active. Blinking indicates any chip activity. In the ZigbeeTLc version, the LED works when the button is pressed or blinks on request "Identify", as well as at the time of pairing or when the network connection is lost. |
I have repeated the flashing process many times without luck. I even read the firware of a brand new device and tried to burn it back, without success. Seems like my flashing set-up does not make it properly... |
Rpi cannot transmit a continuous stream of bytes to UART. |
Interesting. I actually used an RPi 3B for intial flashing as my USB->UART (FTDI) didn't work. You must also connect GND of the MCU and RPi together so they share a common ground. |
Oh and if you are using pigpiod or any other interrupt-based software, disable that before flashing as it might interfere with the correct timings. |
Finally got it to work on the RPI 4 !
Many many thanks both @dbmaxpayne and @pvvx ! |
Hi there, the TS0201-z work and seem to provide reliable temperature (although quite low), but tends to produce data at uneven time. Also, the "measurement interval" setting does not correspond to the indications. I had to set its value to 60 in order to have data every 2 to 4 minutes. |
In Zigbee there are "report" settings. DeepSeek response: ZigBee is a specification for a suite of high-level communication protocols used to create personal area networks with small, low-power digital radios. It is commonly used in home automation, medical data collection, and other low-power low-bandwidth needs. The "report" settings in ZigBee typically refer to the configuration of how and when a device sends data to the coordinator or other devices in the network. Here are some key concepts related to ZigBee reporting settings: Attribute Reporting: In ZigBee, devices can report the status of their attributes (like temperature, humidity, etc.) to the network. The reporting can be configured based on changes in the attribute value or at regular intervals. Reportable Change: This setting determines the minimum change in an attribute's value that must occur before a report is sent. For example, a temperature sensor might be set to report only if the temperature changes by more than 1 degree. Reporting Interval: This is the maximum time interval between reports. Even if the attribute value hasn't changed by the reportable change amount, a report will be sent after this interval has elapsed. Timeout: Some ZigBee devices can be configured to stop reporting if no changes are detected within a certain timeout period. Bindings: ZigBee devices can be bound to each other, meaning that one device is configured to send reports directly to another. This is often used to create direct communication links between sensors and actuators without the need for a central coordinator. Cluster-Specific Reporting: Different clusters (groups of attributes and commands) may have different reporting settings. For example, a lighting cluster might have different reporting requirements than a temperature sensing cluster. Configuration via Commissioning Tools: Reporting settings are typically configured during the commissioning of the ZigBee network using specialized software tools provided by the device manufacturers or ZigBee stack vendors. Over-the-Air (OTA) Configuration: Some ZigBee devices allow for the reporting settings to be configured or updated over the air, which means that the settings can be changed remotely without physical access to the device. ZigBee Cluster Library (ZCL): The ZCL defines a set of clusters and their associated attributes and commands. Reporting settings are often defined within the context of the ZCL. ZigBee Green Power: For devices that are energy harvesting or have very limited power, reporting settings might be optimized to minimize energy consumption, which could mean less frequent reporting or reporting only significant changes. When setting up a ZigBee network, it's important to configure the reporting settings according to the needs of the application to balance between timely data updates and network traffic or power consumption. The specific methods for configuring these settings will depend on the ZigBee stack and tools being used. |
@vjaunet - DeepSeek's full answer to your question:
Hi! It sounds like you're experiencing some inconsistencies with the TS0201-Z temperature sensor, particularly with the measurement interval and data reporting times. Let's break down the potential issues and solutions:
If the "measurement interval" setting doesn't correspond to the actual data reporting frequency, it could be due to: Power-saving mechanisms: Many Zigbee devices are designed to conserve battery life, so they might not report data exactly at the set interval. Zigbee network latency: If your Zigbee network is busy or has interference, the device might delay sending data. Firmware limitations: Some devices have firmware that doesn't strictly adhere to the configured interval. Setting the interval to 60 and getting data every 2–4 minutes suggests the device might be aggregating data or waiting for a specific condition (e.g., significant temperature change) before reporting.
Battery-saving algorithms: The device might wait for a stable connection or a specific time window to send data. Network congestion: If your Zigbee network has many devices or interference, the sensor might delay sending data until the network is clear. Temperature change thresholds: Some sensors only report data if the temperature changes by a certain amount (e.g., 0.5°C). If the temperature is stable, the device might not report data as frequently.
Device configuration in z2m: Ensure the device is properly configured in z2m. Sometimes, settings like reporting interval or battery reporting can affect behavior. z2m logs: Check the z2m logs for any errors or warnings related to the TS0201-Z. This might give you clues about why the data is irregular. z2m version: Ensure you're using the latest version of z2m, as updates often include bug fixes and improvements for specific devices.
Sensor calibration: Some sensors might need calibration or have an offset. Placement: Ensure the sensor is placed in a location that accurately reflects the temperature you want to measure (e.g., away from drafts, direct sunlight, or heat sources). Firmware bug: Check if there are any known issues or firmware updates for the TS0201-Z. Recommendations: Experiment with Settings: Try adjusting the measurement interval and temperature change threshold in z2m to see if it improves the reporting frequency. Test in a Different Location: Move the sensor to a different location to rule out environmental factors affecting the readings. Update Firmware: If the device supports firmware updates, ensure it's running the latest version. Monitor Zigbee Network: Use a tool like z2m's network map to check for interference or weak signal strength that might affect the device's performance. If the issue persists, you might want to reach out to the z2m community or the device manufacturer for further assistance. Let me know if you need help with any of these steps! |
If the CHT8305 sensor is installed. When the battery voltage drops below 2.5V, it often manifests itself as follows: |
I'm currently happy with the devices and dont see the erratic temperature measurement (yet). About the uneven report intervals I have not tried to change anything as Victor's firmware reports every 0.1°C change anyway. |
vjaunet indicated that he has TS0201-z.
The TS0201-z has a CHT8305 sensor installed.
But ZHA sets its own values for report. Changing to the desired settings is possible only by patching the ZHA code. |
|
https://pvvx.github.io/ZY-ZTH02/ - TS0201_TZ3000_v1w2k9dd
Many people do not read carefully what is being discussed and write any questions in all topics. https://pvvx.github.io/TS0201_TZ3000/ - TS0201 _TZ3000_xr3htd96, _TZ3000_qsefbina, display name in Z2M/ZHA: "TS0201-z" |
I confirm that I have TS0201 _TZ3000_v1w2k9dd device that shows up as TS0201-z in z2m.
That is something I was not aware of. I need to dig more into the different possible firmware, but to be honest it is a bit complicated for me to figure all of this out.
I was not aware of that and it that is probably why I am having uneven reports then... I will continue to dig all of that in, but it seems that I need to write an external converter for z2m to correctly handle the device. Thanks guys. |
Would be great if someone could share some hints how to prep an OTA for my TS0201 _TZ3000_v1w2k9dd which is already Zigbee out of the box. Bit unsure how to create something that is recognized by ZHA when using below config.
Note they work out of the box in home assistant but only seem to update when registering big changes in temperature / humidity hence my wish to use this custom firmware.
Bought here
The text was updated successfully, but these errors were encountered: