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.
Tool/software: Code Composer Studio
Hello,
hard to explain - hopefully it is hardware issue - in the end total Resets (Like PURs! Programm starts from zero! But is somehow lost from debugger, it can be stopped, but PC is total out of controll, but the software still runs. If Breakpoints are set at functions, the code must come through, nothing happens. Strange, because normally if a PUR occurs, Debug connections are lost - at least in my impression).
BUT the hardware under test (10 pieces!) performed well for weeks and several software releases.
The only thing what happened two days ago, was an unintended "MSP-FET-UPDATE". Normally I declined it - but it nerved....
Well, since that event, devices show a very very strange behaviour: They reset, at least at a reproducable stage of the code...! But this piece of code is actually the oldest and most tested one of the project.
Questions:
#A: Has anybody else observed similar phenomena after updating the MSP-FET device?
#B: How to control the update behaviour? CAN I suppress it ?
#C: Can I degrade the MSP-FET and Compiler/CCS Studio to older versions?
#D: How can I load a hex-file without building the project? I've got older versions, till now untouched, I would like to flash the old hex-Files.
Thank You in advance - I hope this is the issue... but I keep on investigating the hardware!
Hello Jace,
now for 100 % : there are now voltage drops below 2.2 Volts.
Till now the register SYSRSTIV reads as 0x000A after start up and also after the strange issue occurrs. But 0x0000 after replay of the current debug session.
With best regards
Is there a possibility to run a uC Self test? To test if the memory works properly, the PC, the ISR System?
I'll implement an UART-Based printout of the relevant uC registers, at startup.
If there is no possibility to check this things, I'll have to change the chip for testing.
Thank You Robert,
I've updated CCS and installed it on another computer as reference - no difference obvious.
I'll checkout this debugger option.
The total crazy thing: This type of reset occurs, during UART-Operation - but not the very first Operation, actually there are a lot of operations ahead. Active Interrupts: UART_A0 and the Watchdog Timerinterrupt.
Other (paranoia) question regarding the same trouble shooting: Is everything well defined? I'm not so long working with the MSP430 (cool device, and cool documentation for sure! Thank You TI!) - so I'm not really safe regarding the management of the clocks. As far as I see my registers and my scope by inspecting the timings, the system works. Also compared to the launch-pad circuits and easy programs. There is no XT2 Crystal - it's free - for power saving reasons.One thing not to clear to me: PORT C? On which Pins is it to find?
Question because of a former remark #10372-D: (ULP 4.1) Detected uninitialized Port C in this project. Recommend initializing all unused ports to eliminate wasted current consumption on unused pins.
I've just defined it at the very first line of code by: PCDIR=0x00; PCREN=0xff; PCOUT=0x00;
On which Pins is actually this PortC? What is its function?
Important to know: I don't like beans and such stuff - I prefer coding by documentation on register level.
With best regards
Dr. Bachmayer
Dear Jace,
I'll check this also.
But in my application I use all the benefits of the MSP430. I even controll the power supply voltage between 3V3 and 1V8.
It works - also with 1V8, what is my sleep voltage.
Clock is not touched - so I think it is 1Mhz (quite sure, due to UART configurations...).
All my software does is setting up the watchdog as ISR - source (with lowest possible periodes), configure I2C, SPI, and UART.
All worked and was step by step developed and controlled for function via scope/signal analyzer.
I'll tell You asap the results regarding the Reset source.
The mentioned functionalities are not used at the same time - so ISR interference can't be the issue.
What drives me crazy - when the mentioned voltage drop occurs (at activating a heavy load member of my circuitry), the reset doesn't occur at all. This member (interfaced via UART) sends the initial routine - all fine. BUT, when my UART starts to send it's first commands, it happens. But when I step through - nothing happens, because of the missed answers..... so hard to debug...
I've not only measured the drops, I've additionally added big capacitors, even a strong power supply - it didn't change the effect.
And again: This is not seen on all devices.
Therefore - if it is probably no failure on the IC itself, I think it has to be something like a undefined input. But which inputs could be responsible for such a total reset? The reset Pin has an Pull up of 47kOhm (Pin64 of MSP430F5228 RGC package). Other basic circuitry like on a launchpad: 1k between PUR and PU.0, 1M between PU.0 and VSSU (GND). SBWTCK is open (correct?).
Thank You very much in advance - for sure a stupid beginner mistake, but a cruel one, because it came up very very very late AND not at all devices....
With best regards
Mathias
Dear Jace,
the watchdog is regarding its reset functionality disabled - I use it as a pure Timer Interrupt providing my Time Base for my statemachines:
Setting One: WDTCTL = WDTPW | 0x0040 |0x0007 | WDTTMSEL; // 7 msek Period for ISR
Setting TWO: WDTCTL = WDTPW | 0x0040 |0x0005 | WDTTMSEL; // 873 msek Period for ISR
SFRIE1|=WDTIE;
Correct? Or is the watchdog still anyhow awake?
Moreover I set
UCSCTL6|=XT2OFF;
I'll go now through all the hints (especially from Robert regarding the Breakpoint for resets) and give You a detailed report.
Thank's a lot
With best regards
FYI regarding SYSRSTIV (redundant Information):
long Register;
void main(void){
Register = SYSRSTIV;
delivers:
<watched expressions>|<RegisterView of SYSRSTIV>:
Fresh Loaded : 0x00000000|0x0000
After first Reset (manually halted) : 0x0000000A|0x0000
What looks for me (if I understand the Wiki from Jace correctly) a security violation occurs?!!!!
What means this? I guess it means a pointer is running amok? I'll check the UART-Write routines...
processors.wiki.ti.com/.../SYSRSTIV_Register_options.png
Dear Jace,
Ok, thank You. I'll investigate the UART-Connection - regarding pointer issues.
But thank YOu very very much!
With best regards
Bug found! The Slave device blasts out suddenly 11kByte of data trash - like a denial of service attack ... - during development only <200 Bytes observed. The initialisation routine, didn't take a possible roll over into account (Ringbuffer is 4000 Bytes big).
Bug found, but now facing some program stops caused by a blue arrow with a hint "MSP-430 Debug Call Stack".
I've reset debugger settings to default (because of searching for Robert's hint regarding the Debugger setting) - but no change.
The device works, if I disconnect it totally from the debugger after flashing, initiating the communication.
But if I let the debugger connected, the program stops randomly anywhere with this hint "MSP-430 Debug Call Stack". What does this mean?
Could please anybody explain me, what the "MSP-430 Debug Stack" Message means? Thank You!
**Attention** This is a public forum