This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

MSP430G2553: Temperature sensor calibration constant possibly incorrect

Part Number: MSP430G2553

Tool/software:

Dear Support Team,

We have been using MSP430G2553 in our products for a couple of years and yesterday we encountered a problem with the integrated temperature sensor. One of our devices reported plainly wrong temperature (ca. 18 degrees centigrades) while two other reported ca. 28 degrees (roughly the ambient temparature). All three MCUs are from the same lot (marking 18K C4GP, this is TSSOP-28 version) and from the same shipment from Mouser.

The TLV checksum is verified at startup by our application. The XOR checksum might not be particularly strong, but two accidental writes of INFO A Flash keeping the same checksum are unlikely, particularly that INFO A remains locked all the time, even if we do write to INFO segments B to D and main memory while setting up our application. The MCU is powered from a 3.3 V LDO with Power Good output connected to RST, so it should run safely at 12 MHz MCLK without the risk of undervoltaged CPU going wild.

The ADC10 seems to work properly in general: conversions for internal VCC/2 and an external voltage input give reasonable results. The ADC10 is clocked from SMCLK/6 = 2 MHz and the sampling time is 64 cycles (32 us > 30 us minimum time). It uses the internal 2.5 V reference.

I have checked the calibration constants in the malfunctioning and one of the good chips and there are much different:

Good chip: CAL_ADC_25T30 = 0x1BB, CAL_ADC_25T85 = 0x20D (difference 82)

@10c0 
ce 8e fe 16 ff ff ff ff ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff ff ff 10 10 00 80 00 00
fa 7e e4 02 70 03 4e 7f bb 01 0d 02 fe 08 ff ff
ff ff ff ff ff ff 01 08 83 8f 8e 8e 7f 8d 38 87

Malfunctioning chip: CAL_ADC_25T30 = 0x1C8, CAL_ADC_25T85 = 0x20A (difference 66)

@10c0 
e4 8e fe 16 ff ff ff ff ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff ff ff 10 10 00 80 00 00
9e 7f eb 02 70 03 f5 7f c8 01 0a 02 fe 08 ff ff
ff ff ff ff ff ff 01 08 81 8f 85 8e 7a 8d be 86

I know that one should expect differences, but there should also be a significant difference in the corresponding ADC reading in both chips in similar temperatures, which is not true (around 0x1B4 vs. 0x1B6, which gives about 25 and 15 degrees by linear interpolation in somewhat colder ambient today). We do not expect great accuracy, but 10 degrees of error looks too much.

Please also note that the temperature sensor constants for 1.5 V reference are much more similar for both chips, if that matters at all.

Is this possible that the factory calibration constant are partially invalid for one chip?

Best regards,

Michal

  • Hi Michal,

    Can you send a good quality photo of the top of one of the bad devices?  Also from that particular batch of units, all have the same issue and if so would you happen to know how many of those devices from from lot you purchased?

  • Hi Dennis,

    There were 20 devices in that order (it was June 2022) and they were waiting on our shelf until now, we were using older inventory. We have assembled only three units with these devices, and two of these seem to behave correctly, while just one shows that lowered temperature. I cannot say anything about the remaining devices.

    Here is a photo of the suspected device:

    And this is an unused device freshly taken out from the tube in which they were all shipped:

    Best regards,

    Michal

  • Hi Dennis,

    Could you recommend any action? Just replace the device with next one from the same purchase and test?

    Best regards,

    Michal

  • Hi Michal,

    I apologize for the delay.  No, I wouldn't spend the time replacing the device.  It sounds like the issue is related to the lot, so another device from same lot will most likely have same issue.  I'm working with the production team to locate the production history on this lot.  This may take a day or two.

  • Hi Michal,

    According to our production/test records, this device lot was produced on Oct 7, 2021 and tested with same production SW running since May 2016 ( No updates/changes to this program.)

    Is it possible to check devices that have never been programmed?

  • To further muddy the waters, I checked the G2553 (19AQKHK A) sitting in the (ancient) Launchpad I have:

    010e0: c3 7f e3 02 00 00 57 80 b9 01 00 00 fe 08 ff ff

    Showing zeros for both of the T85 values.

  • Hi Dennis,

    Thank you for the update. I think I have to order a ZIF socket to test the remaining unused devices in our G2 Launchpad. It is more reasonable than start mounting them on remaining bare PCBs.

  • Hi David,

    Interesting.  Since you say it is ancient, it is possible the Launchpad was shipped with pre-release silicon.  This means it may not have had the full production testing in place at that time, but was determined to be ok to build Launchpads with.  This is common when a new device is about to be released.  We want to have Launchpads, docs, etc., the day of the official release, so this means the Launchpads were built 6-8 weeks before the official release and hence "pre-leased" silicon.

  • Hi David,

    Out of curiosity, can you take a photo of the LP, specifically the markings on the MSP package?

    Thanks.

  • I included what seemed to be the date code. They are such low contrast that it required a lot of work to find just the right angle to be able to read. Getting a photo of that...

  • Yes, the reason for the photo is when I looked up the lot id you provided, it came back with a completely different part - TPS62125DSGR.  I was hoping a photo would help.

  • Hi David,

    I have managed to test the remaining 16 devices from that purchase without programming them, applying the following procedure:

    1. Mount the device in a ZIF TSSOP-28 to DIP-28 adapter inserted into the DIP-20 socket of a G2 Launchpad.

    2. Power it on and take control using "Attach to running target" in IAR EW IDE.

    3. Export the contents of INFO A segment to a TXT file and enter the four temperature sensor calibration constants into a spreadsheet.

    4. Import a piece of code into RAM from a TXT file. The code stops WDT, verifies TLV checksum, switches DCO to 12 MHz (as in our standard applications) and reads the temperature sensor using 1.5 V and 2.5 V internal references, trying both at 2.0 MHz and 1.5 MHz ADC10CLK (SMCLK/6, SMCLK/8), i.e., with 32 us and 43 us sampling times, respectively. Each result is averaged over 64 reads and stored as multiplied by 16 (i.e., with 4 fractional bits).

    5. Set PC to the code RAM, put a breakpoint at the end, and run the code.

    6. Enter the results into the spreadsheet to convert them into temperatures.

    At the end, all devices returned into their tube in the same order (hopefully) -- in case some of them need further testing.

    The tests took a few hours (the relatively cheap ZIF adapter I could order immediately did not contact reliably in all pins and I lost much time reinserting the devices and restarting the debugger until I turned the adapter 180 degrees) and the ambient temperature changed a bit in the meantime, but:

    1. For most devices, the results were quite consistent. The extended sampling time did not seem to have significant impact.

    2. A couple of devices (#09, #12, #13) have shown noticeably higher temperatures (by 2 or 3 degrees Celsius) which cannot be attributed to ambient temperature changes (devices #09 to #16 were tested without long breaks between them). One device (#10) shown noticeable difference (ca. 2 degrees) between the results for 1.5 V and 2.5 V reference.

    3. Anyway, the results for none of the tested devices were as bad as the device described in the original post.

    The table below summarizes the results. Two PDIP-20 devices from different lots (used to test the code on the day before) are included for comparison.

    Device TLV constants CAL_ADC_XX Temperature read
    15T30 15T85 25T30 25T85 1.5 Vref 2.5 Vref
    TSSOP-28 devices from lot 18KC4GP
    #01 02EA 0378 01BF 0213 22.2 22.9
    #02 02F4 0378 01C3 0213 23.1 22.7
    #03 02D4 0364 01B0 0207 23.7 23.1
    #04 02E3 036E 01BA 020D 24.7 24.6
    #05 02F4 037D 01C4 021E 25.6 24.8
    #06 02F2 037C 01C3 0215 24.0 24.0
    #07 02DE 036A 01B7 020A 24.5 24.7
    #08 02ED 0376 01BF 0211 25.7 25.3
    #09 02F4 037C 01C3 0215 27.3 26.7
    #10 02EB 0376 01C1 0212 25.8 27.5
    #11 02F2 037B 01C3 0214 25.5 25.8
    #12 02E9 0374 01BD 0210 27.3 27.0
    #13 02E3 036E 01B9 020C 26.8 26.5
    #14 02F1 037A 01C3 0215 24.3 24.3
    #15 02DF 0366 01B8 0208 25.7 25.3
    #16 02E6 036F 01BC 020E 25.0 25.0
    PDIP devices (lot ID given)
    34A8ZZK 02EE 0376 01C0 0211 24.3 23.9
    71CVJZK 02E2 0371 01B9 020F 23.9 23.7


    Should I post the complete TLV dumps?

    Best regards,

    Michal

  • Michal,

    You certainly have gone above and beyond collecting this data - thank you very much for your time and effort.

    Regarding the TLV dumps, hold for now. I'm sharing this data with our production test team and let's see what they come back with.

    Here is a thought...when you perform the ADC measurement, what state is the CPU in?  Active mode or sleeping?  If not in sleep mode, can see if you can modify your code so the CPU and clocks are off to minimize system noise.

  • Hi Michal,

    Do you have any sense of the temperature accuracy or temperature spread in the previous products you built?

  • Hi Dennis,

    Unfortunately, no. The temperature of the critical part of the product is sensed using an external thermistor connected to one of ADC10 inputs. The internal temperature sensor serves as a protection against using the product far beyond recommended conditions, so we do not require great accuracy here. I simply have never observed a temperature reading such obviously different from the ambient temperature as in the device which gave origin to this thread. And I have always used the 2.5 V reference only (because of the range of our other analog signals), so I cannot say anything about 1.5 V readings.

    Actually, our main concern is if the temperature sensor calibration data is the only problem with this device.

  • Hi Michal,

    I wouldn't be concerned about the MSP430 operation (ADC, temp sensor).  In this case it appears the calibration values were programmed incorrectly, on at least 3 devices.  Looking back at historical production data, the team doesn't show any reported issues or changes to the production code that might account for the behavior you are seeing.  The team also indicated that the production calibration can vary by 2-3 degC.

    Since there are other devices in the same lot# that appear to have reasonable calibration values, I would suggest you keep monitoring the situation and notify me if you find additional devices that are way out of calibration.

  • Hi Dennis,

    Thanks for confirming that this is simply the temperature sensor calibration data issue.

    The variation of 2..3 degC could be expected. Too bad that if the errors at 30 and 85 degC calibration points happen to have opposite signs, the extrapolation error below 30 degC can be larger -- but this is simply how extrapolation works.

**Attention** This is a public forum