[Scummvm-tracker] [ScummVM :: Bugs] #14574: GOB: Excessive blitting drags performance down

ScummVM :: Bugs trac at scummvm.org
Sun Aug 13 18:02:48 UTC 2023


#14574: GOB: Excessive blitting drags performance down
----------------------------+------------------------------------
Reporter:  mikrosk          |      Owner:  (none)
    Type:  feature request  |     Status:  new
Priority:  normal           |  Component:  Engine: Gob
 Version:                   |   Keywords:  gobliiins, performance
    Game:  Gobliiins        |
----------------------------+------------------------------------
 Gob::Surface::blit() seems to be called unnaturally often even for basic
 screens (like the initial one in Gobliiins where only 3-4 small objects
 are animated), namely between two updateScreen() calls one can observe:

 left 212, top 5, w 15, h 3, x 212, y 5
 left 0, top 49, w 19, h 29, x 0, y 49
 left 28, top 88, w 19, h 17, x 28, y 88
 left 260, top 0, w 11, h 5, x 204, y 6
 left 264, top 6, w 7, h 3, x 308, y 15
 left 156, top 33, w 27, h 20, x 292, y 128
 left 108, top 0, w 39, h 36, x 224, y 114
 left 256, top 0, w 23, h 27, x 200, y 107
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 264, top 6, w 7, h 3, x 308, y 15
 left 156, top 33, w 27, h 20, x 292, y 128
 left 108, top 0, w 39, h 36, x 224, y 114
 left 256, top 0, w 23, h 27, x 200, y 107
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 264, top 6, w 7, h 3, x 308, y 15
 left 156, top 33, w 27, h 20, x 292, y 128
 left 108, top 0, w 39, h 36, x 224, y 114
 left 256, top 0, w 23, h 27, x 200, y 107
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 196, top 0, w 11, h 19, x 164, y 10
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 196, top 0, w 11, h 19, x 164, y 10
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 196, top 0, w 11, h 19, x 164, y 10
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 252, top 50, w 19, h 19, x 12, y 59
 left 284, top 101, w 19, h 14, x 12, y 48
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 252, top 50, w 19, h 19, x 12, y 59
 left 284, top 101, w 19, h 14, x 12, y 48
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 252, top 50, w 19, h 19, x 12, y 59
 left 284, top 101, w 19, h 14, x 12, y 48
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 252, top 50, w 19, h 19, x 24, y 59
 left 68, top 147, w 19, h 13, x 24, y 49
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 252, top 50, w 19, h 19, x 24, y 59
 left 68, top 147, w 19, h 13, x 24, y 49
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 252, top 50, w 19, h 19, x 24, y 59
 left 68, top 147, w 19, h 13, x 24, y 49
 left 84, top 38, w 31, h 14, x 168, y 40
 left 148, top 0, w 23, h 32, x 176, y 55
 left 84, top 0, w 23, h 37, x 176, y 88
 left 280, top 0, w 39, h 15, x 208, y 100
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 44, top 75, w 15, h 19, x 0, y 59
 left 264, top 120, w 19, h 12, x 0, y 49
 left 264, top 0, w 27, h 23, x 192, y 136
 left 292, top 0, w 23, h 24, x 220, y 130
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 264, top 0, w 27, h 23, x 192, y 136
 left 292, top 0, w 23, h 24, x 220, y 130
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 264, top 0, w 27, h 23, x 192, y 136
 left 292, top 0, w 23, h 24, x 220, y 130
 left 116, top 37, w 35, h 18, x 248, y 92
 left 0, top 0, w 63, h 49, x 0, y 117
 left 200, top 0, w 27, h 29, x 36, y 87
 left 228, top 0, w 27, h 28, x 44, y 58
 left 172, top 0, w 27, h 31, x 52, y 26
 left 64, top 0, w 19, h 39, x 64, y 127
 left 188, top 32, w 131, h 24, x 84, y 142
 left 152, top 0, w 15, h 12, x 32, y 92
 left 20, top 0, w 19, h 19, x 0, y 0
 left 0, top 5, w 287, h 161, x 0, y 5
 left 304, top 15, w 15, h 3, x 304, y 15
 left 0, top 26, w 319, h 140, x 0, y 26
 left 0, top 88, w 319, h 78, x 0, y 88
 left 192, top 107, w 127, h 43, x 192, y 107

 even after this burst it's still not done, copyRectToScreen() is called
 with (x, y, w, h):

 0, 5, 288, 162
 304, 15, 16, 4
 0, 26, 320, 141
 0, 88, 320, 79
 192, 107, 128, 44

 as we can see, with some pretty heavy and overlapping rectangles.

 Combination of those two factors makes the game (and even the cursor
 movement) very jerky on slower platforms.
-- 
Ticket URL: <https://bugs.scummvm.org/ticket/14574>
ScummVM :: Bugs <https://bugs.scummvm.org>
ScummVM


More information about the Scummvm-tracker mailing list