diff options
author | Juan J. Martinez <jjm@usebox.net> | 2023-07-09 23:21:18 +0100 |
---|---|---|
committer | Juan J. Martinez <jjm@usebox.net> | 2023-07-09 23:21:18 +0100 |
commit | fcde38e508cd381ad17e0f73946fa551ac683c81 (patch) | |
tree | 67f1a234760d32a503572929179e2112d79206d9 /src/vga.c | |
parent | d4e9908bf65c080ee2d0e3d143720e0b72bb210d (diff) | |
download | gold-mine-run-fcde38e508cd381ad17e0f73946fa551ac683c81.tar.gz gold-mine-run-fcde38e508cd381ad17e0f73946fa551ac683c81.zip |
Height can be a parameter too
Diffstat (limited to 'src/vga.c')
-rw-r--r-- | src/vga.c | 11 |
1 files changed, 5 insertions, 6 deletions
@@ -197,16 +197,15 @@ void blit_copy(const Rect *dst) } } -void blit_copy16x16(const Rect *dst) +void blit_copy16(const Rect *dst) { uint8_t *src = buffer + dst->x + dst->y * 320; uint8_t *dtarget = screen + dst->x + dst->y * 320; asm volatile ( - "movl $16, %%eax\n\t" "movl $0x130, %%ebx\n\t" "cld\n\t" - "blit_copy16x16_loop:\n\t" + "blit_copy16_loop:\n\t" "movsl\n\t" "movsl\n\t" "movsl\n\t" @@ -215,9 +214,9 @@ void blit_copy16x16(const Rect *dst) "addl %%ebx, %%edi\n\t" "decl %%eax\n\t" "orl %%eax, %%eax\n\t" - "jne blit_copy16x16_loop\n\t" + "jne blit_copy16_loop\n\t" : /* no output */ - : "S" (src), "D" (dtarget) - : "ecx", "ebx", "eax" + : "S" (src), "D" (dtarget), "a" ((uint32_t)dst->h) + : "ecx", "ebx" ); } |