On Wed, Jul 24, 2024 at 09:08:47AM -0600, Simon Glass wrote: > The global data structure has grown quite a lot over the years, being > the best place to put an important pointer or something that must be > accessed before and after relocation. > > This series attempts to reduce the size a little, by moving some things > out and shrinking and aligning some fields. > > Some fields are needed during init but not afterwards. To deal with this > a new 'boardf' structure is created, which sits on the stack and is only > present during board_init_f(). It is possible that more fields could > move to this struct, but for now only 4 are moved. > > An assumption is made that an int is 32-bits wide on all architectures, > which seems to be true, but maintainers should be able to confirm. > > Mostly the code-size impact is neutral, but the patch > 'Use less space for environment fields' does increase U-Boot's size by > about 30 bytes on aarch64. > > For firefly-rk3399 (64-bit) the size of global reduces from 456 to 368 > bytes. For SPL it reduces from 416 to 272 bytes. > > There are other things which could be attempted, for example: > - Using hlist instead of list for some lists > - Checking that only necessary fields are present in SPL
This is good, thanks for doing this. I'm planning to grab this in to -next once I open it. -- Tom
signature.asc
Description: PGP signature