-
Notifications
You must be signed in to change notification settings - Fork 215
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
Add option to use the main app's heap #1609
Comments
Wouldn't just increasing the WiFi heap (and lowering free RAM) be the same or did I miss something? |
Right now I have two heaps. Their allocation (i.e. how much is assigned to wifi and how much to my app) can't really change based on what state my firmware is in. Using a single heap would probably make things just a bit more flexible - no memory reserved for wifi when not needed, etc. I guess an alternative solution could be registering esp-wifi's heap as the global allocator, if needed. |
Speaking of heaps, there are a bunch of things the API would like to allocate, but we provide static objects instead. There are a few assumption in code (like queue size of 200) that aren't really elegant and could instead be allocated on heap. Are we opposed to doing this, or are the current static objects mostly just quick and dirty solutions? |
TL;DR the initial implementation was to just get things going - I'm aware these are naive implementations The initial implementation originates from me trying to get WiFi and BLE working on another RV32 SoC (it worked) and was more like a POC - but it helped a lot to get this working and a lot of the not so nice code here is just copied from there. I planned on refactoring many of those naive implementations but then got hit by a lot of problems caused by the Xtensa enabled compiler. I think that should be fine now since the compiler got much, much better recently but I didn't get to work on that yet |
@bjoernQ How about adding the alloc feature? Then a bunch of wifi will use the app's global alocator. The question is whether there will be any problems if this alocator is configured on psram |
Probably allocating in PSRAM would get us into problems, yes. And the allocator-API doesn't allow us to ask for "special" kinds of memory Some opt-in-feature would still be fine (with a nice warning comment). In any case we should stay "no-alloc" (i.e. not needing a global allocator) by default |
Of course, by default there will be “its own” heap. I'm now trying to add this functionality. I'll post the results |
Well PSRAM
Static alocator (practically the same as in the crate, only on the application side)
This is not clear to me at all For the allocator I used esp-alloc This is draft changes: esp-rs/esp-wifi-sys#415 |
Static allocation is fixed by lto="thin" |
With what lto setting did you experience the panic? |
@bugadani false |
I mean specifically what was the old setting out of |
Sorry. Corrected previous message |
If use psram, Wi-Fi does not work. I think need to somehow separate the allocations that can be made in psram and those that should be static |
I don't propose for this to be the only way, as heap fragmentation might bite some use cases, but it might not be a bad tool - I sometimes have 100k or so RAM I can lend to the wifi stack :)
The text was updated successfully, but these errors were encountered: