Add instruction for Thermostat EEM #36

Merged
esavkin merged 1 commits from morgan/assembly:therm-eem into master 2025-01-08 12:44:25 +08:00
4 changed files with 182 additions and 0 deletions

View File

@ -20,6 +20,7 @@
- [Sinara 8452 DSP Stabilizer / Sinara 4459 Pounder](./hw/stabilizer_pounder.md) - [Sinara 8452 DSP Stabilizer / Sinara 4459 Pounder](./hw/stabilizer_pounder.md)
- [Sinara 9805 RF Power Amplifier Booster](./hw/booster.md) - [Sinara 9805 RF Power Amplifier Booster](./hw/booster.md)
- [Sinara 8451 Thermostat](./hw/thermostat.md) - [Sinara 8451 Thermostat](./hw/thermostat.md)
- [Sinara 8453 Thermostat EEM](./hw/thermostat_eem.md)
- [Sinara 2245 LVDS DIO](./hw/lvds_dio.md) - [Sinara 2245 LVDS DIO](./hw/lvds_dio.md)
- [Software/Support](./sw_sup/software_support.md) - [Software/Support](./sw_sup/software_support.md)
- [Starting with ARTIQ](./sw_sup/artiq_start.md) - [Starting with ARTIQ](./sw_sup/artiq_start.md)

181
src/hw/thermostat_eem.md Normal file
View File

@ -0,0 +1,181 @@
# Sinara 8453 Thermostat EEM
* [Wiki](https://github.com/sinara-hw/Thermostat_EEM/wiki)
* [Firmware](https://github.com/quartiq/thermostat-eem/tree/main)
EEM is used for power only, and it can be alternatively powered by 12V barrel jack or PoE.
## JSON
Not present in the JSON.
### Building
There is no Nix Flake support to make things easier, so you need to set up rust and cargo manually.
Start with cloning the thermostat-eem repository and opening a new shell with dfu-util (for flashing) and rustup
(for building).
```shell
nix-shell -p dfu-util rustup
```
Set up the toolchain, this should be done only once:
```shell
rustup target add thumbv7em-none-eabihf
cargo install cargo-binutils
rustup component add llvm-tools-preview
rustup update
rustup default stable
```
Building:
```shell
cargo build --release
cargo objcopy --release --bin thermostat-eem -- -O thermostat-eem.bin
```
## Flashing
Once you have the binary, you can now flash it.
1. Without firmware on the device or with older firmware (without USB serial console),
you need to use the jumper method:
1. Have the Thermostat EEM disconnected from power.
2. Use a jumper of some sort to short BOOT pins on the board.
3. Turn on the power.
4. You can remove the jumper after few seconds.
2. With newer firmware with USB serial console:
1. Connect the Thermostat EEM to power.
2. Connect USB cable to the Thermostat EEM.
3. Ensure you have `pyserial` module either with `nix-shell -p python312Packages.pyserial` for NixOS users
or using `pip install pyserial` if you are using venv.
4. Run `python -m serial /dev/ttyACM0` to connect the serial port using `pyserial`.
5. Input `platform dfu` in the console.
3. Once the device is now in DFU mode, flash the device with the following command (needs `nix-shell -p dfu-util`):
```shell
dfu-util -a 0 -s 0x08000000:leave -R -D thermostat-eem.bin
```
4. Look for "File downloaded successfully".
### Clearing settings
In case someone sets some setting wrongly, or updates the firmware and suddenly there's an incompatibility,
you may find (firmware, not yourself) in a state of panic, where it will not allow you to change the settings back.
1. Get into DFU mode (described above), probably with jumper method.
2. Use dfu-util to clear the flash completely:
```shell
dfu-util -a 0 -s 0x08000000:mass-erase:force:leave
```
3. Reflash the target firmware.
## Testing
### Setting up MQTT
MQTT is the only way to access the SENS and TEC pins telemetry for testing .
On PC side:
1. Get IP address of your machine, e.g. with ``ip a``. Make note of it, that's the broker address.
2. Get mosquitto, e.g. with ``nix-shell -p mosquitto``.
3. Create a mosquitto config files by running ``echo -e "allow_anonymous true\nlistener 1883" > mosquitto.conf``
3. Run mosquitto with the config ``mosquitto -c mosquitto.conf``
4. If you don't have it yet, download [MQTT Explorer](https://github.com/thomasnordquist/MQTT-Explorer/releases).
5. Call ``nix-shell -p appimage-run``, then ``appimage-run MQTT-Explorer-0.4.0-beta6.AppImage``.
6. Connect to the MQTT broker under your own IP address.
Configure Thermostat EEM:
1. Ensure that the [firmware](#Building) has been flashed onto the Thermostat EEM
2. Connect the Thermostat EEM to power.
3. Connect USB cable to the Thermostat EEM.
4. Run ``cutecom`` or your favorite terminal emulator, connect to ``/dev/ttyACM0``.
5. Change the broker setting with: ``set /net/broker "<ip of your machine>"``.
6. Store the setting with ``store /net/broker``.
7. (Optional) Set the IP address of the Thermostat EEM by following steps 4 and 5, but with ``/net/ip`` setting instead.
8. Reboot with ``platform reboot``.
Now, disconnect the USB and connect the Ethernet cable to the Thermostat EEM, as both won't fit at the same time.
Thermostat EEM should connect to moquitto automatically, and you should see the MQTT settings pop up in the MQTT Explorer.
If the IP address is not set, Thermostat EEM will try to use DHCP to get an address.
### SENS pins testing
1. Power off the Thermostat EEM
2. Connect the breakout board to Thermostat EEM
3. Connect two 10k Ohm resistor to SENS0 & SENS1
![resistor for sens pin](../img/thermostat_eem_resistor.jpg)
4. Power the Thermostat EEM and access the `telemetry/statistics` on MQTT Explorer
5. Check the mean temperature is around 25C for SENS0 & SENS1
```json
{
...
"statistics": [
// SENS0 & SENS1
[
{
"mean": 25.180674,
"ptp": 0.00029182434,
"std": 0.000053144646
},
{
"mean": 25.042572,
"ptp": 0.00029182434,
"std": 0.00005036032
},
null,
null
],
// SENS2 & SENS3
[
{
"mean": -273.15,
"ptp": 0,
"std": 0
},
{
"mean": -273.15,
"ptp": 0,
"std": 0
},
null,
null
],
...
],
...
}
```
6. Repeat 3-5 for other SENS pins
### TEC pins testing
1. Power off the Thermostat EEM
2. Connect the breakout board to Thermostat EEM
3. Power the Thermostat EEM and set `output/0/state` parameter to `On` using MQTT explorer
![mqtt setup](../img/thermostat_eem_mqtt.png)
4. Check that TEC0 pins have voltages as described in `telemetry/monitor/output_voltage`
```json
{
"monitor": {
...
"output_voltage": [
-1.1107178, // TEC0
-1.638794, // TEC1
-1.762146, // TEC2
-1.1976318 // TEC3
],
...
},
...
}
```
5. Repeat 3-4 for other TEC pins

Binary file not shown.

After

Width:  |  Height:  |  Size: 46 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 678 KiB