# HG changeset patch # User michael # Date 1025383811 0 # Node ID 5ddfba86d5a4853e3f26ade70b29ef34a1ee3fe6 # Parent 62ce54563e563c04f0c5cd3ff957ca2e1ad53b0a fixing memory overwrite bugs again ... diff -r 62ce54563e56 -r 5ddfba86d5a4 postproc/rgb2rgb_template.c --- a/postproc/rgb2rgb_template.c Sat Jun 29 16:27:48 2002 +0000 +++ b/postproc/rgb2rgb_template.c Sat Jun 29 20:50:11 2002 +0000 @@ -63,13 +63,13 @@ const uint8_t *s = src; const uint8_t *end; #ifdef HAVE_MMX - uint8_t *mm_end; + const uint8_t *mm_end; #endif end = s + src_size; #ifdef HAVE_MMX __asm __volatile(PREFETCH" %0"::"m"(*s):"memory"); + mm_end = end - 23; __asm __volatile("movq %0, %%mm7"::"m"(mask32):"memory"); - mm_end = (uint8_t*)((((unsigned long)end)/24)*24); while(s < mm_end) { __asm __volatile( @@ -114,12 +114,12 @@ const uint8_t *s = src; const uint8_t *end; #ifdef HAVE_MMX - uint8_t *mm_end; + const uint8_t *mm_end; #endif end = s + src_size; #ifdef HAVE_MMX __asm __volatile(PREFETCH" %0"::"m"(*s):"memory"); - mm_end = (uint8_t*)((((unsigned long)end)/32)*32); + mm_end = end - 31; while(s < mm_end) { __asm __volatile( @@ -196,12 +196,12 @@ register const uint8_t* s=src; register uint8_t* d=dst; register const uint8_t *end; - uint8_t *mm_end; + const uint8_t *mm_end; end = s + src_size; #ifdef HAVE_MMX __asm __volatile(PREFETCH" %0"::"m"(*s)); __asm __volatile("movq %0, %%mm4"::"m"(mask15s)); - mm_end = (uint8_t*)((((unsigned long)end)/16)*16); + mm_end = end - 15; while(s