...
Thermistor Cell Input number | Bottom Resistor Value | Expected Voltage (10k upper resistor, 3V0 ref) | Temperature Result Expected |
---|---|---|---|
0 | 10k | 1.5 | 25 |
1 | 3.3k | 0.74436 | 52 |
2 | 10k | 1.5 | 25 |
3 | 4.7k | 0.959186 | 43 |
4 | 10k | 1.5 | 25 |
5 | 5.1k | 1.013245 | 41 |
6 | 10k | 1.5 | 25 |
7 | 6.8k | 1.214285 | 34 |
8 | 10k | 1.5 | 25 |
9 | 10k pot | 0-1.5 | 25+ |
10 | 10k | 1.5 | 25 |
11 | 3.3k | 0.74436 | 52 |
12 | 4.7k | 0.959186 | 43 |
13 | 5.1k | 1.013245 | 41 |
14 | 6.8k | 1.214285 | 34 |
15 | 10k | 1.5 | 25 |
16 | 10k | 1.5 | 25 |
17 | 1.5@25C | 25 |
Updates
...
July 9, 2020
There were a few bugs to work out in the code to print the values, but they didn’t match what was expected. I probed the COMM lines between the 2 chips, and there was nothing - just held to 5V for 2s (beofore the chip goes to sleep) with the pullup resistor. (pins 17,18,19)
I also probed the output of the chip - pulled to GND for the whole time. (pin 43)
...
I (Micah Black will hard-code some more stuff while Gerald Aryeetey (Deactivated) looks in to a fix for this.
Updates
...
July 10, 2020
We fixed the PEC and the correct order for the COMM register data bits.
...
Next steps I’ll try getting some wires soldered to the TQFP mux package and hopefully connect them to the logic analyzer or scope so we can see what is actually happening (I had verified communication was present measuring just 1 channel at a time, so I am unsure if timings are accurate.
Updates July 11, 2020
I hooked up the LTC external SPI interface (the one to the MUX) to the logic analyzer and verified that the signal is getting passed along correctly.
This screenshot should be correctly setting the bits A2 and A0 to enable the input 5 of the mux.
...
None of this makes sense…
So going back through the configuration and reading everything carefully:
ADG731: Data is shifted in to the register, MSB first, on the FALLING edge of the clock.
Checking this against the logic analyzer output, it was set up to sample on the RISING edge of the clock (CPHA=1). Swapping this to the correct CPHA=0 for sampling on the falling edge:
(This is the same spot in the transmission as the above diagram)
...
Notice that all the bits are shifted by 1, and the there is a ‘1' that gets shifted in to the first nEN bit of the ADG731’s input shift register. Thus, the mux is NEVER ENABLED. I think we found our problem.
Time to dig through the LTC6811 datasheet and see if the external SPI mode can be changed.
And I think we have a bigger problem than we realized here. The LTC6811 only supports SPI MODE 3:
...
Which is in conflict with what the ADG731 supports - either:
CPOL=1, CPHA=0 for SPI MODE 2
CPOL=0, CPHA=1 for SPI MODE 1
So at this point, we need to find a way to modify the interface, or we need to find a new MUX.
Options:
AGD732 - The ADG732 is a parallel controlled 32ch mux. Pins A0-A5 control the channel, and the WR pin must be toggled in order to latch the input data. This means that we need 6 pins to control it, and thus the device is not compatible.
Modify Interface - The LTC6811 outputs are Open-Drain, and the inputs on the ADG731 I believe are high impedance. If we invert the clock signal, I think we will be able to get sampling in the correct spot of the signal. SCLK is on pin 19 of the ADG731, and pin 33 of the LTC6811. The signal is pulled HIGH to 5V0 with R1.
...
I think I can cut the trace between PIN 19 and R1 and insert an N-FET and an extra pull-up resistor to achieve the signal inversion.
This is the circuit that would be put in between the pins to invert the clock:
...