<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class="">Pete,<div class=""><br class=""></div><div class="">I just caught my clock taking a pause in the display update, presumably while it fetched a weather update. Somewhere there’s a library using a delay() or in a blocking loop which is blocking my display thread, despite pinning.</div><div class=""><br class=""></div><div class="">Grrrr.<br class=""><div><br class=""><blockquote type="cite" class=""><div class="">On Jan 24, 2020, at 8:33 AM, Mike Lisanke <<a href="mailto:mikelisanke@gmail.com" class="">mikelisanke@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class="">Ok, thanks for the clarification. <br class=""></div><br class=""><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Jan 24, 2020 at 7:57 AM <<a href="mailto:triembed@matrixwide.com" class="">triembed@matrixwide.com</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div style="overflow-wrap: break-word;" class="">On ESP boards in Arduino you get freeRTOS built-in (no need to include anything). I guess this is because the Espresstif libraries include it.<div class=""><br class=""></div><div class="">I’m mainly concerned with the scheduler not interrupting the character sending process for the HD44800 LCD. So far it seems a 'vTaskDelay(1);’ in each thread has things working well. Mutex would usually be to lock a shared resource but I was considering it just as way to stop other threads while the LCD is written.</div><div class=""><br class=""></div><div class="">Alex<br class=""><div class=""><br class=""><blockquote type="cite" class=""><div class="">On Jan 24, 2020, at 7:43 AM, Mike Lisanke <<a href="mailto:mikelisanke@gmail.com" target="_blank" class="">mikelisanke@gmail.com</a>> wrote:</div><br class=""><div class=""><div dir="ltr" class="">It's been my understanding that Arduino is single threaded (except for their own interrupt handling) and that single use resources could be handled in your user code (the main loop) anywhere without conflict (multi-use) because you would naturally structure the code to use a resource (and clean up) then use the resource again... If you're doing your own threading model then it would benefit us to understand What you've implemented to split your tasks among many cycles of the main loop. I just googled and it doesn't appear that Arduino has a multi-tasking component of its loop But of course there are many open source extensions to the basis setup. <div class=""><br class=""></div><div class="">Are you primarily concerned with common use of the I2C bus? Is you "mutex" just a bit/byte/word of memory that you're in a stream to an external device and need to complete it? Or, does mutex imply you have a supervisor interpreting the availability of a resource and selecting whether or not to "dispatch" a thread (section of code) to execute based on the resource availability?</div></div><br class=""><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Jan 23, 2020 at 5:51 PM Alex via TriEmbed <<a href="mailto:triembed@triembed.org" target="_blank" class="">triembed@triembed.org</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">I’m working on a time and weather forecast clock based on an ESP32 and a 20x4 HD44800 LCD connected via an I2C port expander thing. I’m ‘cheating’ at the moment by splitting the display update code and the weather-fetch code into two tasks and pinning them to separate cores.<br class="">
<br class="">
I think the right way to do this is to protect the LCD at the character-sending level with a mutex, but I dread what I may find in terms of how they have overloaded the usual Arduino print and println functions. I should probably also replace my global ‘locking’ access to the network with a mutex, since NTP and the weather updates could clash.<br class="">
<br class="">
Anyone already do something similar to this who would like to share code?<br class="">
<br class="">
Thanks,<br class="">
Alex<br class="">
_______________________________________________<br class="">
Triangle, NC Embedded Computing mailing list<br class="">
<br class="">
To post message: <a href="mailto:TriEmbed@triembed.org" target="_blank" class="">TriEmbed@triembed.org</a><br class="">
List info: <a href="http://mail.triembed.org/mailman/listinfo/triembed_triembed.org" rel="noreferrer" target="_blank" class="">http://mail.triembed.org/mailman/listinfo/triembed_triembed.org</a><br class="">
TriEmbed web site: <a href="http://triembed.org/" rel="noreferrer" target="_blank" class="">http://TriEmbed.org</a><br class="">
To unsubscribe, click link and send a blank message: mailto:<a href="mailto:unsubscribe-TriEmbed@bitser.net" target="_blank" class="">unsubscribe-TriEmbed@bitser.net</a>?subject=unsubscribe<br class="">
<br class="">
</blockquote></div><br clear="all" class=""><div class=""><br class=""></div>-- <br class=""><div dir="ltr" class="">Best regards, Mike</div>
</div></blockquote></div><br class=""></div></div></blockquote></div><br clear="all" class=""><div class=""><br class=""></div>-- <br class=""><div dir="ltr" class="gmail_signature">Best regards, Mike</div>
</div></blockquote></div><br class=""></div></body></html>