<div dir="ltr">John,<div><br></div><div>You are correct. The ESP8266 is not multi-threading. The Task is however interrupting execution of the assembly code when it times out. So instead of getting a nice clean break at the end of your current code line, this can occur anywhere. An example might be strcpy. It's several assembly instructions long. So when the timer runs out, we don't know the status of that copy. Are the pointers updated? Are we half way through? Is a garbage collection in progress? We simply don't know. By contrast, bit operators compile to a single offencive instruction. Chances of collision are much lower, and thus why they make the recommendation to use them. Despite the differences, the implementation behind C, C++ and Python are almost identical.</div><div><br></div><div>Best of luck!</div><div>Mike</div><div><br></div><div><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Tue, Jan 26, 2021 at 4:41 PM John Vaughters <<a href="mailto:jvaughters04@yahoo.com" target="_blank">jvaughters04@yahoo.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Mike,<br>
<br>
Maybe I am misunderstanding. To my knowledge the ESP8266 is not multi-threading. If this library is working as I expect, it is all happening sequential through millis() and micro(). Now I admit that I based that statement off the Ticker Lib from Arduino and this library is different, so I have not verified this still to be the case. But assuming it is, we should not get any kind of race condition if it is sequential. If my tasks are fast enough, the watchdog should be happy too. <br>
<br>
I ended up making a task for every second to create a 1 ms task to fill an array of 20 values with a constant looping increment var and a scheduled task to fire 25 ms later to shut off the 1 ms task. So every second it fires two tasks the first task is shut down by the second task 25 ms later and then averages the 20 readings. All global vars which I use generously in such small programs. I have a feeling the Ticker folks are covering their bases on the flag setting concept, just to help people be successful. I think if you use it within certain parameters, you should be ok.<br>
<br>
Never made the jump to python, C is my go to, but I muddle through C++ pretty good. However, every time I delved into python, I liked it alot. Maybe REPL will be the motivation to stick with it a bit. Truth is I am kind of language confused. I use so many so often that I cannot keep it all straight. But I always feel comfortable in C. But references are your friend when bouncing the way I do. To me, it's the basics. I know what programming can do, I just need to find the syntax. But I am quite amazed by the newer languages and how they make things so easy. C# being a great example. I always find PHP manageable. Python REPL may be the thing for my robots, I love the concept.<br>
<br>
So far the new timer method is working like a charm, but I will let it soak. Now I have to give back some time to work. `,~)<br>
<br>
John Vaughters<br>
<br>
<br>
<br>
On Tuesday, January 26, 2021, 3:39:49 PM EST, Michael Monaghan via TriEmbed <<a href="mailto:triembed@triembed.org" target="_blank">triembed@triembed.org</a>> wrote: <br>
<br>
<br>
<br>
<br>
<br>
John,<br>
<br>
> I am not sure why you could not change a variable if it is global and done fast.<br>
<br>
Because we have no idea what state the variables were in when the service routine was called. Were they being inspected by main code? Or modified? Perhaps Garbage collection is in progress? Without a bit of blocking code to demand a known state, we're flying blind.<br>
<br>
> I may try that when I get around to the Robotics with the ESP32. That is very interesting for sure. I like the REPL concept alot.<br>
Robotics are on the wish list... I just have about 3 million lines of code before I can take on another hobby.<br>
<br>
Python is my go-to language. Only rarely do I have to use C++ to force the solution.<br>
<br>
Mike<br>
<br>
On Tue, Jan 26, 2021 at 2:45 PM John Vaughters via TriEmbed <<a href="mailto:triembed@triembed.org" target="_blank">triembed@triembed.org</a>> wrote:<br>
> Carl,<br>
> <br>
> I do not NEED the delay, I just need to read the A0 at 1 ms intervals. I don't need to stop the processor for that, I need to code it responsibly if I want it to work the best way I want. I was being lazy expecting my time frame to be well within the parameters required for the desired end result. And the solution I finally did does work, but I have now been motivated to make it better.<br>
> <br>
> Mike,<br>
> <br>
> Good info thanks. I have not verified, but yes I am thinking I may have violated the watch dog. I am not sure why you could not change a variable if it is global and done fast. I also dug a little deeper and the ticker I am using is not the same that you find in Arduino. The one I am using is suggesting the flag concept as I pointed out in the first post and is working and the idea you also reinforced. I guess in general it is the simplest guarantee for accurate loop integrity. It definitely works quite well. I have looked at the micro-python. I may try that when I get around to the Robotics with the ESP32. That is very interesting for sure. I like the REPL concept alot.<br>
> <br>
> I can spend a little more time for a better solution. Dang it and I thought I was done with this part. `,~)<br>
> <br>
> Thanks,<br>
> <br>
> John Vaughters<br>
> <br>
> _______________________________________________<br>
> Triangle, NC Embedded Computing mailing list<br>
> <br>
> To post message: <a href="mailto:TriEmbed@triembed.org" target="_blank">TriEmbed@triembed.org</a><br>
> List info: <a href="http://mail.triembed.org/mailman/listinfo/triembed_triembed.org" rel="noreferrer" target="_blank">http://mail.triembed.org/mailman/listinfo/triembed_triembed.org</a><br>
> TriEmbed web site: <a href="http://TriEmbed.org" rel="noreferrer" target="_blank">http://TriEmbed.org</a><br>
> To unsubscribe, click link and send a blank message: mailto:<a href="mailto:unsubscribe-TriEmbed@bitser.net" target="_blank">unsubscribe-TriEmbed@bitser.net</a>?subject=unsubscribe<br>
> <br>
> <br>
<br>
_______________________________________________<br>
Triangle, NC Embedded Computing mailing list<br>
<br>
To post message: <a href="mailto:TriEmbed@triembed.org" target="_blank">TriEmbed@triembed.org</a><br>
List info: <a href="http://mail.triembed.org/mailman/listinfo/triembed_triembed.org" rel="noreferrer" target="_blank">http://mail.triembed.org/mailman/listinfo/triembed_triembed.org</a><br>
TriEmbed web site: <a href="http://TriEmbed.org" rel="noreferrer" target="_blank">http://TriEmbed.org</a><br>
To unsubscribe, click link and send a blank message: mailto:<a href="mailto:unsubscribe-TriEmbed@bitser.net" target="_blank">unsubscribe-TriEmbed@bitser.net</a>?subject=unsubscribe<br>
<br>
</blockquote></div>