commit 668eab05bfa7a828312341b32ba0dccd36c39548
parent 5af50c7ca02c74f6ddb3e3098918a1ed94a65d94
Author: neauoire <aliceffekt@gmail.com>
Date: Fri, 24 Dec 2021 09:29:26 -0800
(ppu) Minor optimisation
Diffstat:
1 file changed, 8 insertions(+), 6 deletions(-)
diff --git a/src/devices/ppu.c b/src/devices/ppu.c
@@ -12,6 +12,8 @@ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
WITH REGARD TO THIS SOFTWARE.
*/
+/* byte: p0-bg | p0-fg | p1-bg | p1-fg */
+
static Uint8 blending[5][16] = {
{0, 0, 0, 0, 1, 0, 1, 1, 2, 2, 0, 2, 3, 3, 3, 0},
{0, 1, 2, 3, 0, 1, 2, 3, 0, 1, 2, 3, 0, 1, 2, 3},
@@ -46,7 +48,7 @@ ppu_resize(Ppu *p, Uint16 width, Uint16 height)
p->pixels = pixels;
p->width = width;
p->height = height;
- ppu_clear(p, 0x00);
+ ppu_clear(p, CLEAR_BOTH);
}
void
@@ -61,11 +63,11 @@ Uint8
ppu_read(Ppu *p, Uint16 x, Uint16 y)
{
if(x < p->width && y < p->height) {
- Uint32 row = (x + y * p->width) / 2;
- Uint8 shift = !(x & 0x1) << 2;
+ Uint32 row = (x + y * p->width) >> 1;
+ Uint8 shift = (x & 0x1) << 2;
Uint8 pix = p->pixels[row] >> shift;
if(pix & 0x0c)
- pix = pix >> 2;
+ pix >>= 2;
return pix & 0x3;
}
return 0x0;
@@ -75,8 +77,8 @@ void
ppu_write(Ppu *p, Uint8 layer, Uint16 x, Uint16 y, Uint8 color)
{
if(x < p->width && y < p->height) {
- Uint32 row = (x + y * p->width) / 2;
- Uint8 shift = (!(x & 0x1) << 2) + (layer << 1);
+ Uint32 row = (x + y * p->width) >> 1;
+ Uint8 shift = ((x & 0x1) << 2) + (layer << 1);
Uint8 pix = p->pixels[row];
Uint8 mask = ~(0x3 << shift);
Uint8 pixnew = (pix & mask) + (color << shift);