forked from sinara-hw/assembly
Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
60c603264f | |||
d5ac5a541e | |||
71e5e8fd16 | |||
008394c117 |
@ -10,15 +10,17 @@
|
||||
- [Sinara 2118 BNC-TTL / 2128 SMA-TTL](./hw/bnc_sma_ttl.md)
|
||||
- [Sinara 2138 MCX-TTL](./hw/mcx_ttl.md)
|
||||
- [Sinara 5432 DAC Zotino / Sinara 5632 DAC Fastino](./hw/zotino_fastino.md)
|
||||
- [Sinara 5633 HV Amplifier](./hw/hvamp.md)
|
||||
- [Sinara 5716 DAC Shuttler](./hw/shuttler.md)
|
||||
- [Sinara 5518 BNC-IDC / 5528 SMA-IDC adapter](./hw/bnc_sma_idc_adapter.md)
|
||||
- [Sinara 4410/4412 DDS Urukul (AD9910/AD9912)](./hw/urukul.md)
|
||||
- [Sinara 5108 Sampler](./hw/sampler.md)
|
||||
- [Sinara 6302 Grabber](./hw/grabber.md)
|
||||
- [Sinara 7210 Clocker](./hw/clocker.md)
|
||||
- [Sinara 8452 DSP Stabilizer](./hw/stabilizer.md)
|
||||
- [Sinara 8452 DSP Stabilizer / Sinara 4459 Pounder](./hw/stabilizer_pounder.md)
|
||||
- [Sinara 9805 RF Power Amplifier Booster](./hw/booster.md)
|
||||
- [Sinara 8451 Thermostat](./hw/thermostat.md)
|
||||
- [Sinara 8453 Thermostat EEM](./hw/thermostat_eem.md)
|
||||
- [Sinara 2245 LVDS DIO](./hw/lvds_dio.md)
|
||||
- [Software/Support](./sw_sup/software_support.md)
|
||||
- [Starting with ARTIQ](./sw_sup/artiq_start.md)
|
||||
|
29
src/hw/hvamp.md
Normal file
29
src/hw/hvamp.md
Normal file
@ -0,0 +1,29 @@
|
||||
# Sinara 5633 HV Amplifier
|
||||
|
||||
* [Wiki](https://github.com/sinara-hw/HVAMP_32/wiki)
|
||||
|
||||
## Setup
|
||||
|
||||
1. Connect the HV Amplifier to the Zotino/Fastino with IDC connectors (stand-alone mode) or with mezzanine connectors (meazzanine mode). Be aware of pin alignment when using it in the meazzanine mode
|
||||
2. Connect the DC barrel or ATX cable to HV Amplifier but **don't supply power**
|
||||
|
||||
## Testing
|
||||
|
||||
After running `artiq_sinara_test` on the connected Zotino/Fastino:
|
||||
|
||||
```text
|
||||
*** Testing Zotino DACs and USER LEDs.
|
||||
Voltages:
|
||||
zotino0 0.1 -0.1 0.2 -0.2 0.3 -0.3 0.4 -0.4 0.5 -0.5 0.6 -0.6 0.7 -0.7 0.8 -0.8 0.9 -0.9 1.0 -1.0 1.1 -1.1 1.2 -1.2 1.3 -1.3 1.4 -1.4 1.5 -1.5 1.6 -1.6
|
||||
Press ENTER when done.
|
||||
|
||||
*** Testing Fastino DACs and USER LEDs.
|
||||
Voltages:
|
||||
fastino0 0.1 -0.1 0.2 -0.2 0.3 -0.3 0.4 -0.4 0.5 -0.5 0.6 -0.6 0.7 -0.7 0.8 -0.8 0.9 -0.9 1.0 -1.0 1.1 -1.1 1.2 -1.2 1.3 -1.3 1.4 -1.4 1.5 -1.5 1.6 -1.6
|
||||
Press ENTER when done.
|
||||
```
|
||||
|
||||
1. Turn on the external power supply connecting to the HV Amplifier **(⚠️Danger: High Voltage active, don't touch the bare PCB without PPE)**
|
||||
2. Probe with multimeter/DC voltmeter each pair of pins from bottom to top (left pins are ground)
|
||||
3. Check that respective pins have voltages multipled by the gains as described by `artiq_sinara_test` (e.g. for 5x gain variant 0.1V pin => 0.1V x 5 = 0.5V )
|
||||
4. Check LEDs are on
|
@ -133,3 +133,46 @@ Configure Stabilizer:
|
||||
Now, disconnect the USB and connect the Ethernet cable to the Stabilizer, as both won't fit at the same time.
|
||||
Stabilizer 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, Stabilizer will try to use DHCP to get an address.
|
||||
|
||||
## Installing the Pounder
|
||||
|
||||
Remember that the Pounder is not fully supported in official QUARTIQ release; use the firmware from Hydra.
|
||||
|
||||
Use ESD precautions; ensure that power is off (both barrel jack and PoE) before installing or removing the card.
|
||||
|
||||
There are no guides for the Pounder connector. Line up the connectors with the pins and gently push in.
|
||||
|
||||
SMA connectors should line up with the ones from Stabilizer; no pins should be visible from the sides of the Pounder; it's more obvious if the Pounder has the front panel already installed.
|
||||
|
||||
## Testing the Pounder
|
||||
|
||||
### With serial only
|
||||
|
||||
You need to have the Stabilizer powered on and connected through USB. Ethernet is not necessary.
|
||||
|
||||
Input the following sequence of commands into the shell, assuming Stabilizer serial interface is visible at /dev/ttyACM0:
|
||||
```
|
||||
stty 115200 -F /dev/ttyACM0
|
||||
echo 'set /dual_iir/pounder/out_channel/0/dds/frequency 20e6' > /dev/ttyACM0
|
||||
echo 'set /dual_iir/pounder/out_channel/0/dds/amplitude 1' > /dev/ttyACM0
|
||||
echo 'set /dual_iir/pounder/out_channel/0/attenuation 16' > /dev/ttyACM0
|
||||
echo 'set /dual_iir/pounder/out_channel/1/dds/frequency 30e6' > /dev/ttyACM0
|
||||
echo 'set /dual_iir/pounder/out_channel/1/dds/amplitude 1' > /dev/ttyACM0
|
||||
echo 'set /dual_iir/pounder/out_channel/1/attenuation 16' > /dev/ttyACM0
|
||||
```
|
||||
|
||||
You can copy them all and input at once.
|
||||
|
||||
Observe a sine wave with frequency of 20MHz on channel 0 output, and 30MHz on channel 1 output.
|
||||
|
||||
### With MQTT (slower)
|
||||
|
||||
For this method, you need to set up MQTT and have the Stabilizer connected with Ethernet.
|
||||
|
||||
1. Set up the MQTT as described above.
|
||||
2. Using Mosquitto and MQTT Explorer, set the pounder ``out_channel`` parameters:
|
||||
* Frequency: 20e6 (20MHz)
|
||||
* Amplitude: 1.0
|
||||
![Pounder MQTT settings](../img/pounder_mqtt.png)
|
||||
3. Repeat the procedure for the other channel.
|
||||
4. Observe a sine wave of given frequency with an oscilloscope in the output channel.
|
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/pounder_mqtt.png
Normal file
BIN
src/img/pounder_mqtt.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 22 KiB |
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