diff options
author | Julius Werner <jwerner@chromium.org> | 2016-06-30 22:34:57 -0700 |
---|---|---|
committer | Aaron Durbin <adurbin@chromium.org> | 2016-07-02 03:22:51 +0200 |
commit | e9808b145f592db1cf9daaaad6ac42982f13f218 (patch) | |
tree | 792e0c65536863f28548a4fe566daf0f0b745060 /payloads/libpayload/LICENSES | |
parent | fadfc2e2f6abbcaea7bbc92c13716c5382443993 (diff) | |
download | coreboot-e9808b145f592db1cf9daaaad6ac42982f13f218.tar.xz |
cbgfx: Use memset() for faster screen clearing if possible
cbgfx currently makes a separate function call (recomputing some values)
for every single pixel it draws. While we mostly don't care that much
about display speed, this can become an issue if you're trying to paint
the whole screen white on a lowly-clocked Cortex-A53. As a simple
solution for these extreme cases, we can build a fast path into
clear_screen() that just memset()s the whole framebuffer if the color
and pixel format allow it.
BUG=chrome-os-partner:54416
TEST=Screen drawing speed on Kevin visibly improves (from 2.5s to 3ms).
Change-Id: I22f032afbb86b96fa5a0cbbdce8526a905c67b58
Signed-off-by: Julius Werner <jwerner@chromium.org>
Reviewed-on: https://review.coreboot.org/15524
Tested-by: build bot (Jenkins)
Reviewed-by: Daisuke Nojiri <dnojiri@chromium.org>
Reviewed-by: Aaron Durbin <adurbin@chromium.org>
Diffstat (limited to 'payloads/libpayload/LICENSES')
0 files changed, 0 insertions, 0 deletions