[U-Boot] [PATCH 0/3] arm: reduce .bss section clear time

Przemyslaw Marczak p.marczak at samsung.com
Wed Jan 28 15:10:39 CET 2015


Hello Stefan,

On 01/28/2015 02:12 PM, Stefan Roese wrote:
> Hi Przemyslaw,
>
> On 28.01.2015 13:55, Przemyslaw Marczak wrote:
>> This patchset reduces the boot time for ARM architecture,
>> Exynos boards, and boards with DFU enabled(ARM).
>>
>> For tested Trats2 device, this was done in three steps.
>>
>> First was enable the arch memcpy and memset.
>> The second step was enable memset for .bss clear.
>> The third step for reduce this operation is to keep .bss section
>> small as possible.
>>
>> The .bss section will grow if we have a lot of static variables.
>> This section is cleared before jump to the relocated U-Boot,
>> and it's done word by word. To reduce the time for this step,
>> we can enable arch memset, which uses multiple ARM registers.
>>
>> For configs with DFU enabled, we can find the dfu buffer in this section,
>> which has at least 8MB (32MB for trats2). This is a lot of useless data,
>> which is not required for standard boot. So this buffer should be dynamic
>> allocated.
>>
>> Przemyslaw Marczak (3):
>>    exynos: config: enable arch memcpy and arch memset
>>    arm: relocation: clear .bss section with arch memset if defined
>>    dfu: mmc: file buffer: remove static allocation
>>
>>   arch/arm/lib/crt0.S             | 10 +++++++++-
>>   drivers/dfu/dfu_mmc.c           | 25 ++++++++++++++++++++++---
>>   include/configs/exynos-common.h |  3 +++
>>   3 files changed, 34 insertions(+), 4 deletions(-)
>
> Looking at the commit messages of this patchset I can conclude that your
> overall boot time reduction is:
>
> from ~1527ms
> to ~464ms
>
> This is amazing! Congrats. :)
>

Thank you. I was also amazed.

The time results are taken with from the clock cycle counter, I think 
it's reliable.  Some day I would like to check it using the oscilloscope.

> We really should in general make more use of the optimized functions and
> take care that the buffers (e.g. the DFU buffer in this case) are used
> in a sane way.
>
> Thanks,
> Stefan
>
>

Yes you're right, I thought that Exynos config has enabled arch 
memcpy/set lib, before I checked this...

Best regards,
-- 
Przemyslaw Marczak
Samsung R&D Institute Poland
Samsung Electronics
p.marczak at samsung.com


More information about the U-Boot mailing list