forked from sinara-hw/assembly
Add instruction for Thermostat EEM
This commit is contained in:
parent
d5ac5a541e
commit
60c603264f
@ -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
181
src/hw/thermostat_eem.md
Normal 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
|
BIN
src/img/thermostat_eem_mqtt.png
Normal file
BIN
src/img/thermostat_eem_mqtt.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 46 KiB |
BIN
src/img/thermostat_eem_resistor.jpg
Normal file
BIN
src/img/thermostat_eem_resistor.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 678 KiB |
Loading…
Reference in New Issue
Block a user