[SLOF] [PATCH v2 0/2] fbuffer: Improve the speed of the cursor drawing
Alexey Kardashevskiy
aik at ozlabs.ru
Mon Aug 3 13:00:15 AEST 2015
On 07/30/2015 10:56 PM, Thomas Huth wrote:
> Greg Kurz recently already did a great work by introducing the
> invert-region helpers to speed up the drawing of the cursor.
> This made the grub2 command prompt and editor mode usable.
> However, the editor mode of grub2 is still sluggish - because
> grub2 always redraws the whole line (with cursor enabled!) when
> you enter a character, and since cursor and character drawing
> is still not super-fast in SLOF, this sums up to a noticable delay.
>
> So I tried to speed up the drawing a little bit and came up
> with the following patches. I've used a little "benchmark"
> in Forth to see how the patches improve the drawing:
>
> 1 buffer: etest-buf
> : etest
> erase-screen
> 41 etest-buf c!
> 1b emit 5b emit [char] H emit
> cursor-on
> milliseconds
> 20 0 do 3a 0 do etest-buf 1 terminal-write drop loop cr loop
> milliseconds
> swap -
> ." Duration: " .d ." ms" cr
> ;
>
> Without my patches, the etest function takes 1.8 s to draw.
> With the first patch applied, the function take ca. 1.2 s.
> With both patches applied, the function only takes ca. 0.8 s !
>
> The first patch changes invert-region to use a bigger
> access width if possible. And the second patch simply
> decreases the size of the cursor from a full-character
> size rectangle to an underscore-like cursor instead...
> not sure whether this is acceptable, but at least I
> think it looks as good as the original cursor.
>
>
> Changes:
>
> v2:
> - Small optimization in the first patch with "3 and" according
> to the suggestion of Segher
> - Decreased the size of the cursor to 2 lines instead of 3 in
> the second patch - IMHO still looks fine and saves some more
> few precious cycles.
Thanks, applied.
>
>
> Thomas Huth (2):
> fbuffer: Improve invert-region helper
> fbuffer: Use a smaller cursor
>
> board-js2x/slof/helper.fs | 13 ++++++++-----
> board-qemu/slof/helper.fs | 14 ++++++++++----
> slof/fs/fbuffer.fs | 5 +++--
> 3 files changed, 21 insertions(+), 11 deletions(-)
>
--
Alexey
More information about the SLOF
mailing list