English | 简体中文
tuyaopen is an open source IoT development framework that supports cross-chip platforms and operating systems. It is designed based on a universal southbound interface and supports communication protocols such as Bluetooth, Wi-Fi, and Ethernet. It provides core functionalities for IoT development, including pairing, activation, control, and upgrading. The sdk has robust security and compliance capabilities, including device authentication, data encryption, and communication encryption, meeting data compliance requirements in various countries and regions worldwide.
IoT products developed using the tuyaopen, if utilizing the functionality of the tuya_cloud_service component, can make use of the powerful ecosystem provided by the Tuya APP and cloud services, and achieve interoperability with Power By Tuya devices.
At the same time, the tuyaopen will continuously expand, providing more cloud platform integration features, as well as voice, video, and facial recognition capabilities.
Ubuntu and Debian
$ sudo apt-get install lcov cmake-curses-gui build-essential wget git python3 python3-pip python3-venv libc6-i386 libsystemd-dev
$ git clone https://github.com/tuya/tuyaopen.git
The tuyeopen repository contains multiple submodules. The tos tool will check and automatically download the submodules before compilation, or you can manually download them using the command git submodule update --init
.
$ cd tuyaopen
$ export PATH=$PATH:$PWD
Or add the tuyaopen path to your system environment variables.
tuyaopen can be compiled and debugged using the tos command, which will search for the tuyaopen repository based on the path set in the environment variables and execute the corresponding operations.
For detailed usage of the tos command, please refer to tos command.
The tos tool configures the build platform through the project_build.ini
file located in the project's directory. The project_build.ini
file includes the following fields:
- project: The name of the project, which can be customized. It is recommended to use the format _<platform/chip name>.
- platform: The target platform for compilation, with available options including: ubuntu, t2, t3, t5, esp32, ln882h, bk7231x. This name should match the name defined in
platform/platform_config.yaml
. - chip: Optional values; when the selected platform supports multiple chips, the specific chip name must be specified.
- When the platform is set to esp32, the available options are: esp32, esp32c3.
- When the platform is set to bk7231x, the available options are: bk7231n.
An example configuration is as follows:
[project:sample_project_bk7231x]
platform = bk7231x
chip = bk7231n
Additionally, the tos tool can configure the simultaneous compilation of projects across multiple platforms via the project_build.ini
file. For more information, refer to [Multi-platform Configuration](#Multi-platform Configuration).
Select the corresponding project for the current compilation in examples or apps, and then run the following command to compile:
$ cd examples/get-started/sample_project
$ tos build
After compilation, the target files will be located in the examples/get-started/sample_project/.build/t2/bin/t2_1.0.0
directory.
To configure the selected examples or apps project, run the following command in the corresponding project directory for menu-driven configuration:
$ cd examples/get-started/sample_project
$ tos menuconfig
Configure the current project, save and exit after configuration, and then compile the project.
Name | Support Status | Introduction | Debug log serial port |
---|---|---|---|
Ubuntu | Supported | Can be run directly on Linux hosts such as ubuntu. | |
T2 | Supported | Supported Module List: T2-U | Uart2/115200 |
T3 | Supported | Supported Module List: T3-U T3-U-IPEX T3-2S T3-3S T3-E2 etc. | Uart1/460800 |
T5 | Supported | Supported Module List: T5-E1 T5-E1-IPEX etc. | Uart1/460800 |
ESP32/ESP32C3 | Supported | Uart0/115200 | |
LN882H | Supported | Uart1/921600 | |
BK7231N | Supported | Supported Module List: CBU CB3S CB3L CB3SE CB2S CB2L CB1S CBLC5 CBLC9 CB8P etc. | Uart2/115200 |
raspberry pico-w | In Development, to be released in Nov 2024 |
The tyutool gui
flashing tool supports serial port flashing for multiple chips such as T2/T3/T5/BK7231N/LN882H, and is compatible with Windows/Linux/macOS operating systems. Please choose the corresponding GUI flashing tool based on your operating system.
- Windows: tyutool_win
- Linux: tyutool_linux.tar
- macOS x86: tyutool_mac_x86
- macOS arm64: tyutool_mac_arm64.zip
You can flash the device with a single command using tos flash
.
- In environments like Linux, you need to set the serial port permissions first using the following command; otherwise, an error will occur during execution.
$ sudo usermod -aG dialout $USER
- Run the
tos flash
command in the directory of the compiled project for one-click flashing. Thetos flash
command will automatically download the correspondingtyutool
tool based on the current running environment and proceed with the flashing process.
$ cd examples/get-started/sample_project
$ tos flash
tyutool params:
[INFO]: tyut_logger init done.
[INFO]: Run Tuya Uart Tool.
[INFO]: Use default baudrate: [921600]
[INFO]: Use default start address: [0x00]
--------------------
1. /dev/ttyS0
2. /dev/ttyS1
3. /dev/ttyS2
4. /dev/ttyS3
5. /dev/ttyS4
6. /dev/ttyS5
7. /dev/ttyS6
8. /dev/ttyS7
9. /dev/ttyS8
10. /dev/ttyS9
11. /dev/ttyS10
12. /dev/ttyS11
13. /dev/ttyS12
14. /dev/ttyS13
15. /dev/ttyS14
16. /dev/ttyS15
17. /dev/ttyS16
18. /dev/ttyS17
19. /dev/ttyS18
20. /dev/ttyS19
21. /dev/ttyS20
22. /dev/ttyS21
23. /dev/ttyS22
24. /dev/ttyS23
25. /dev/ttyS24
26. /dev/ttyS25
27. /dev/ttyS26
28. /dev/ttyS27
29. /dev/ttyS28
30. /dev/ttyS29
31. /dev/ttyS30
32. /dev/ttyS31
33. /dev/ttyUSB0
^^^^^^^^^^^^^^^^^^^^
Select serial port: 33 ## Select the correct serial port
[INFO]: Waiting Reset ...
[INFO]: unprotect flash OK.
[INFO]: sync baudrate 921600 success
Erasing: ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 100% 4 bytes/s 0:00:04 / 0:00:00
[INFO]: Erase flash success
Writing: ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 100% 16 bytes/s 0:00:18 / 0:00:00
[INFO]: Write flash success
[INFO]: CRC check success
[INFO]: Reboot done
[INFO]: Flash write success.
Note: During the flashing process, you need to enter the boot mode according to the actual situation of the chip before performing serial port flashing.
The tuyaopen provides a variety of sample projects to facilitate developers in quickly getting started and understanding the usage of the tuyaopen.
$ tuyaopen
├── ai
│ └── llm_demo
├── ble
│ ├── ble_central
│ └── ble_peripher
├── get-started
│ └── sample_project
├── peripherals
│ ├── adc
│ ├── gpio
│ ├── i2c
│ ├── pwm
│ ├── spi
│ ├── timer
│ └── watchdog
├── protocols
│ ├── http_client
│ ├── mqtt
│ ├── tcp_client
│ └── tcp_server
├── system
│ ├── os_event
│ ├── os_kv
│ ├── os_mutex
│ ├── os_queue
│ ├── os_semaphore
│ ├── os_sw_timer
│ └── os_thread
└── wifi
├── ap
├── low_power
├── scan
└── sta
Each sample project includes a README.md file that provides detailed instructions on configuring, compiling, and running the project.
tuyaopen provides a wealth of cloud connectivity application examples, which can be found in the apps directory. You can click Cloud Connectivity Applications for more information.
tuyaopen supports adding and adapting new platforms. For specific operations, please refer to Adding and Adapting New Platforms.
-
The supported platform for tuyaopen are dynamically downloaded through subrepositories. Updating the tuyaopen repository itself will not automatically update the subrepositories. If you encounter any issues with compilation, please navigate to the corresponding directory in the "platform" folder and use the
git pull
command to update, or delete the corresponding directory in the "platform" folder and download it again. -
tuyaopen provides a wealth of cloud connectivity application examples. If you encounter issues such as being unable to connect or activate devices properly, please refer to Cloud Connectivity Applications.
Distributed under the Apache License Version 2.0. For more information, see LICENSE
.
If you are interested in the tuyaopen and wish to contribute to its development and become a code contributor, please first read the Contribution Guide.
Users should be clearly aware that this project may contain submodules developed by third parties. These submodules may be updated independently of this project. Considering that the frequency of updates for these submodules is uncontrollable, this project cannot guarantee that these submodules are always the latest version. Therefore, if users encounter problems related to submodules when using this project, it is recommended to update them as needed or submit an issue to this project.
If users decide to use this project for commercial purposes, they should fully recognize the potential functional and security risks involved. In this case, users should bear all responsibility for any functional and security issues, perform comprehensive functional and safety tests to ensure that it meets specific business needs. Our company does not accept any liability for direct, indirect, special, incidental, or punitive damages caused by the user's use of this project or its submodules.
- Arduino for tuyaopen: https://github.com/tuya/arduino-tuyaopen
- Luanode for tuyaopen:https://github.com/tuya/luanode-tuyaopen