-
Notifications
You must be signed in to change notification settings - Fork 13.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Renamings for that esp_yield
is really suspend, replacing delay(0), shimmable suspend-CONT API for async esp_suspend() / esp_schedule()
#7148
Conversation
CI bombed again, this time for MacOS :-( |
0513ce5
to
c32b24a
Compare
esp_schedule(); | ||
esp_yield(); | ||
} | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
How about commenting the choice of this name (is it interrupting tasks calling (delay()
) from cont stack) and also that it is equivalent to delay(0)
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If new function names are to be added, with restrictions on usage, like "use esp_break() if code is called from SYS", I suggest adding _from_sys
in its name to make it clear.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yield()
historically panics on purpose when it is called from SYS.
esp_break()
is exactly yield()
without panic()
, callable from both cont and sys.
Considering that the yield()
's panic()
is avoided by delay(0)
or its new flavour esp_break()
, then we may just update yield()
to not panic no ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't know what happened, but you must not have available the current sources somehow.
The actual comment now states, I think I adapted it after an earlier discussion:
// Replacement for delay(0). In CONT, same as yield(). Whereas yield() panics
// in SYS, esp_break() is safe to call and only schedules CONT. Use yield()
// whereever only called from CONT, use esp_break() if code is called from SYS
// or both CONT and SYS.
Meaning, esp_break()
is intended for both SYS and CONT.
With regard to yield()
panicking in SYS, whereas delay(0)
does not and esp_break()
of course does neither, I think this was discussed and it was stated that yield()
shall intentionally continue panicking when called from anywhere else but CONT.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I forgot to disable my previous answer before the last one. Sorry that this confused you.
So you propose esp_break()
for both sys and cont because yield()
is for cont only, while they both do the same job, like delay(0)
which currently is used to replace yield()
everywhere where it is needed for sys and cont.
Then, you replace delay(0)
by the new sys+cont yield()
taste.
So we have now yield()
, delay(0)
, esp_break()
?
Why not simply yield()
with a comment ?
If the earlier discussion you refer to is that one, it also says:
We could fix it for a major release
@devyte maybe you can elaborate on this:
The expressibility issue has been discussed before (a long time ago shortly after I arrived). It was deemed valid
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@d-a-v Thanks, one can never look too many times at the code. I'm going to explain next that it's a bit different than you think, but that wasn't helped by me replacing delay(0)
by yield()
on time too often - instead of by esp_break()
(5c39094).
Then, you replace delay(0) by the new sys+cont yield() taste.
So we have now yield(), delay(0), esp_break() ?
Why not simply yield() with a comment ?
Delay(0)
is either pointless, in those places where the code runs only ever from CONT, so for final clarity and to let the runtime panic
to express that contract, I'm replacing it by yield()
. Again, only in those places.
Wherever code may run from SYS (and perhaps from CONT, too), the new esp_break()
must be used to replace delay(0)
. This is to make the intention clear not to panic
in SYS, which I find obfuscated by a zero time delay(0)
call.
As you can see, yield()
(intentional panic in SYS) is not the same as esp_break()
, and my reservations about delay(0)
I've explained above.
ebaec92
to
bc49412
Compare
48a4cb2
to
401670e
Compare
4976bc6
to
5c39094
Compare
5c39094
to
2940729
Compare
2940729
to
6ad28cf
Compare
5f22bea
to
cd03fa9
Compare
24806f8
to
8e92256
Compare
a3d08f1
to
2a39360
Compare
Should we understand that you're in the need for a personalized explanation of why it is useful for ethernet ? |
Not really... I've commented at times before about "separation of concern" issues, but let us not go deeper into that. Also, no need to get personal at all. |
Strange, I was observing rom going down from 317933 before and 317853 after. Ram remained the same. https://gist.github.com/mcspr/50e7c8ee2bc9c27bc8e83dd0e7aae111 |
@mcspr Thank you for your contribution. I may not have taken the time to analyze further otherwise. Yes, your change shaves 160 bytes off the IROM usage - that's for the pristine WiFiScan.ino example sketch. I'm committing your change, with a small refactoring of the const references on uint32_t that I think were unintended. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lgtm
besides the comments and the commit & title could be improved for squashing?
some historical reference
- delay() refactoring #6212, here is a more complete replacement of delay(0) usage across the Core
- introduce
yieldUntil(untilFunction, timeoutMs)
#8317 here, implement delay on a lower level - WiFiScan.ino ported to CoopTask libraries doesn't find any networks #7969 since we deal with a bunch of weak funcs, here internal libraries reference the exact functionality they want
- Delay(0) is an obfuscation of yield() or esp_schedule(); esp_yield() #7146 discussion originated the UART changes, as noticed with the delay(0) vs. yield() usage
Co-authored-by: Max Prokhorov <[email protected]>
f6e07a1
to
863c482
Compare
esp_yield
is really suspend, replacing delay(0), shimmable suspend-CONT API for async esp_suspend() / esp_schedule()
…ve microoptimization that could break on inlining.
Fix in-source specification for the main `esp_try_delay`.
@dok-net can you merge master branch here or unlock the modifications by the maintainers on the right column? |
@mcspr Done |
The main API change here concerns the renaming of
esp_yield()
toesp_suspend()
. This can be detected by 3rd party libraries through the newHAVE_ESP_SUSPEND
define.Lots of internal renamings to make the difference between suspending and yielding, the latter meaning suspend and resume at the next opportunity, more succinct.
Hint: This PR now contains, due to sizeable merge efforts each time, and they are related, everything that's in PR #6782 as well.
Fixes #7969
Related items:
#6212, here is a more complete replacement of delay(0) usage across the Core
#8317 here, implement delay on a lower level
#7969 since we deal with a bunch of weak funcs, here internal libraries reference the exact functionality they want
#7146 discussion originated the UART changes, as noticed with the delay(0) vs. yield() usage