#include <stdint.h>
#include <fb.h>
+#include <crc32.h>
uint32_t checksum_rect_generic32(int x, int y, int width, int height) {
*/
int scanline = fb->curmode.xres * 4;
- uint32_t * lineaddr;
- int i, j;
+ unsigned char * lineaddr;
+ int i;
uint32_t sum = 0;
for (i = 0; i < height; i++) {
- lineaddr = (uint32_t *)(fb->fbaddr + (i + y) * scanline);
+ lineaddr = fb->fbaddr + (i + y) * scanline + (4 * x);
- for (j = 0; j < width; j++) {
- sum += lineaddr[j + x];
- }
+ sum = crc32(lineaddr, width * 4, sum);
}
return sum;
int cx, cy;
unsigned int *ibuf = (unsigned int *)buf;
unsigned int *fbuf;
- for (cy = y; cy < (y + height); cy++)
+ for (cy = 0; cy < height; cy++)
{
fbuf = (unsigned int *)fb->fbaddr;
- fbuf += y * (fb->curmode.xres) + x;
- for (cx = x; cx < (x + width); cx++)
+ fbuf += (cy + y) * (fb->curmode.xres) + x;
+ for (cx = 0; cx < width; cx++)
*(ibuf++) = *(fbuf++);
}
}