2021-11-11 10:27 PM
2021-11-12 12:25 AM
Without an operating-system or other tasking techniques, your processor is either doing things or in-a-tight-loop waiting for more things to do.
A "bare metal" approach to showing processor load would be to light an LED when the processor starts this waiting loop, and turns it off as soon as it has found something to do.
More advanced techniques are possible. Something I often do is "profile" my code, where I have a timer interrupt. Inside the interrupt-service-routine, I examine the return address to know where the processor was interrupted from and store that. (To save RAM I typically have 256 "bins" or address-ranges, and add 1 to the appropriate bin). Once I've run the code long enough to get something representative, I can then log the results.
This way I can know not only what portion of time the processor is executing at-or-near the idle routine, but also what portion of time it spends in other routines so I can know which routines are worth my effort optimising, and which ones use so little cpu time that it's not worth trying.
Hope this helps,
Danish
2021-11-12 12:25 AM
Without an operating-system or other tasking techniques, your processor is either doing things or in-a-tight-loop waiting for more things to do.
A "bare metal" approach to showing processor load would be to light an LED when the processor starts this waiting loop, and turns it off as soon as it has found something to do.
More advanced techniques are possible. Something I often do is "profile" my code, where I have a timer interrupt. Inside the interrupt-service-routine, I examine the return address to know where the processor was interrupted from and store that. (To save RAM I typically have 256 "bins" or address-ranges, and add 1 to the appropriate bin). Once I've run the code long enough to get something representative, I can then log the results.
This way I can know not only what portion of time the processor is executing at-or-near the idle routine, but also what portion of time it spends in other routines so I can know which routines are worth my effort optimising, and which ones use so little cpu time that it's not worth trying.
Hope this helps,
Danish