mirror of
				https://github.com/webmproject/libwebp.git
				synced 2025-10-26 16:13:41 +01:00 
			
		
		
		
	upsampling_{neon,sse41}: fix int sanitizer warning
fixes warnings of the form:
/src/dsp/upsampling_sse41.c:170:1: runtime error: implicit conversion
  from type 'int' of value -16 (32-bit, signed) to type 'uintptr_t' (aka
  'unsigned long') changed the value to 18446744073709551600 (64-bit,
  unsigned)
this is the same change as was done previously in upsampling_sse2.c:
2ee786c7 upsampling_sse2.c: clear int sanitizer warnings
Change-Id: I36064d837ad1a7a118918c16a5551fc732dec2ff
			
			
This commit is contained in:
		| @@ -189,57 +189,57 @@ static const int16_t kCoeffs1[4] = { 19077, 26149, 6419, 13320 }; | ||||
|   }                                                                     \ | ||||
| } | ||||
|  | ||||
| #define NEON_UPSAMPLE_FUNC(FUNC_NAME, FMT, XSTEP)                       \ | ||||
| static void FUNC_NAME(const uint8_t* top_y, const uint8_t* bottom_y,    \ | ||||
|                       const uint8_t* top_u, const uint8_t* top_v,       \ | ||||
|                       const uint8_t* cur_u, const uint8_t* cur_v,       \ | ||||
|                       uint8_t* top_dst, uint8_t* bottom_dst, int len) { \ | ||||
|   int block;                                                            \ | ||||
|   /* 16 byte aligned array to cache reconstructed u and v */            \ | ||||
|   uint8_t uv_buf[2 * 32 + 15];                                          \ | ||||
|   uint8_t* const r_uv = (uint8_t*)((uintptr_t)(uv_buf + 15) & ~15);     \ | ||||
|   const int uv_len = (len + 1) >> 1;                                    \ | ||||
|   /* 9 pixels must be read-able for each block */                       \ | ||||
|   const int num_blocks = (uv_len - 1) >> 3;                             \ | ||||
|   const int leftover = uv_len - num_blocks * 8;                         \ | ||||
|   const int last_pos = 1 + 16 * num_blocks;                             \ | ||||
|                                                                         \ | ||||
|   const int u_diag = ((top_u[0] + cur_u[0]) >> 1) + 1;                  \ | ||||
|   const int v_diag = ((top_v[0] + cur_v[0]) >> 1) + 1;                  \ | ||||
|                                                                         \ | ||||
|   const int16x4_t coeff1 = vld1_s16(kCoeffs1);                          \ | ||||
|   const int16x8_t R_Rounder = vdupq_n_s16(-14234);                      \ | ||||
|   const int16x8_t G_Rounder = vdupq_n_s16(8708);                        \ | ||||
|   const int16x8_t B_Rounder = vdupq_n_s16(-17685);                      \ | ||||
|                                                                         \ | ||||
|   /* Treat the first pixel in regular way */                            \ | ||||
|   assert(top_y != NULL);                                                \ | ||||
|   {                                                                     \ | ||||
|     const int u0 = (top_u[0] + u_diag) >> 1;                            \ | ||||
|     const int v0 = (top_v[0] + v_diag) >> 1;                            \ | ||||
|     VP8YuvTo ## FMT(top_y[0], u0, v0, top_dst);                         \ | ||||
|   }                                                                     \ | ||||
|   if (bottom_y != NULL) {                                               \ | ||||
|     const int u0 = (cur_u[0] + u_diag) >> 1;                            \ | ||||
|     const int v0 = (cur_v[0] + v_diag) >> 1;                            \ | ||||
|     VP8YuvTo ## FMT(bottom_y[0], u0, v0, bottom_dst);                   \ | ||||
|   }                                                                     \ | ||||
|                                                                         \ | ||||
|   for (block = 0; block < num_blocks; ++block) {                        \ | ||||
|     UPSAMPLE_16PIXELS(top_u, cur_u, r_uv);                              \ | ||||
|     UPSAMPLE_16PIXELS(top_v, cur_v, r_uv + 16);                         \ | ||||
|     CONVERT2RGB_8(FMT, XSTEP, top_y, bottom_y, r_uv,                    \ | ||||
|                   top_dst, bottom_dst, 16 * block + 1, 16);             \ | ||||
|     top_u += 8;                                                         \ | ||||
|     cur_u += 8;                                                         \ | ||||
|     top_v += 8;                                                         \ | ||||
|     cur_v += 8;                                                         \ | ||||
|   }                                                                     \ | ||||
|                                                                         \ | ||||
|   UPSAMPLE_LAST_BLOCK(top_u, cur_u, leftover, r_uv);                    \ | ||||
|   UPSAMPLE_LAST_BLOCK(top_v, cur_v, leftover, r_uv + 16);               \ | ||||
|   CONVERT2RGB_1(VP8YuvTo ## FMT, XSTEP, top_y, bottom_y, r_uv,          \ | ||||
|                 top_dst, bottom_dst, last_pos, len - last_pos);         \ | ||||
| #define NEON_UPSAMPLE_FUNC(FUNC_NAME, FMT, XSTEP)                              \ | ||||
| static void FUNC_NAME(const uint8_t* top_y, const uint8_t* bottom_y,           \ | ||||
|                       const uint8_t* top_u, const uint8_t* top_v,              \ | ||||
|                       const uint8_t* cur_u, const uint8_t* cur_v,              \ | ||||
|                       uint8_t* top_dst, uint8_t* bottom_dst, int len) {        \ | ||||
|   int block;                                                                   \ | ||||
|   /* 16 byte aligned array to cache reconstructed u and v */                   \ | ||||
|   uint8_t uv_buf[2 * 32 + 15];                                                 \ | ||||
|   uint8_t* const r_uv = (uint8_t*)((uintptr_t)(uv_buf + 15) & ~(uintptr_t)15); \ | ||||
|   const int uv_len = (len + 1) >> 1;                                           \ | ||||
|   /* 9 pixels must be read-able for each block */                              \ | ||||
|   const int num_blocks = (uv_len - 1) >> 3;                                    \ | ||||
|   const int leftover = uv_len - num_blocks * 8;                                \ | ||||
|   const int last_pos = 1 + 16 * num_blocks;                                    \ | ||||
|                                                                                \ | ||||
|   const int u_diag = ((top_u[0] + cur_u[0]) >> 1) + 1;                         \ | ||||
|   const int v_diag = ((top_v[0] + cur_v[0]) >> 1) + 1;                         \ | ||||
|                                                                                \ | ||||
|   const int16x4_t coeff1 = vld1_s16(kCoeffs1);                                 \ | ||||
|   const int16x8_t R_Rounder = vdupq_n_s16(-14234);                             \ | ||||
|   const int16x8_t G_Rounder = vdupq_n_s16(8708);                               \ | ||||
|   const int16x8_t B_Rounder = vdupq_n_s16(-17685);                             \ | ||||
|                                                                                \ | ||||
|   /* Treat the first pixel in regular way */                                   \ | ||||
|   assert(top_y != NULL);                                                       \ | ||||
|   {                                                                            \ | ||||
|     const int u0 = (top_u[0] + u_diag) >> 1;                                   \ | ||||
|     const int v0 = (top_v[0] + v_diag) >> 1;                                   \ | ||||
|     VP8YuvTo ## FMT(top_y[0], u0, v0, top_dst);                                \ | ||||
|   }                                                                            \ | ||||
|   if (bottom_y != NULL) {                                                      \ | ||||
|     const int u0 = (cur_u[0] + u_diag) >> 1;                                   \ | ||||
|     const int v0 = (cur_v[0] + v_diag) >> 1;                                   \ | ||||
|     VP8YuvTo ## FMT(bottom_y[0], u0, v0, bottom_dst);                          \ | ||||
|   }                                                                            \ | ||||
|                                                                                \ | ||||
|   for (block = 0; block < num_blocks; ++block) {                               \ | ||||
|     UPSAMPLE_16PIXELS(top_u, cur_u, r_uv);                                     \ | ||||
|     UPSAMPLE_16PIXELS(top_v, cur_v, r_uv + 16);                                \ | ||||
|     CONVERT2RGB_8(FMT, XSTEP, top_y, bottom_y, r_uv,                           \ | ||||
|                   top_dst, bottom_dst, 16 * block + 1, 16);                    \ | ||||
|     top_u += 8;                                                                \ | ||||
|     cur_u += 8;                                                                \ | ||||
|     top_v += 8;                                                                \ | ||||
|     cur_v += 8;                                                                \ | ||||
|   }                                                                            \ | ||||
|                                                                                \ | ||||
|   UPSAMPLE_LAST_BLOCK(top_u, cur_u, leftover, r_uv);                           \ | ||||
|   UPSAMPLE_LAST_BLOCK(top_v, cur_v, leftover, r_uv + 16);                      \ | ||||
|   CONVERT2RGB_1(VP8YuvTo ## FMT, XSTEP, top_y, bottom_y, r_uv,                 \ | ||||
|                 top_dst, bottom_dst, last_pos, len - last_pos);                \ | ||||
| } | ||||
|  | ||||
| // NEON variants of the fancy upsampler. | ||||
|   | ||||
| @@ -123,7 +123,7 @@ static void FUNC_NAME(const uint8_t* top_y, const uint8_t* bottom_y,           \ | ||||
|   int uv_pos, pos;                                                             \ | ||||
|   /* 16byte-aligned array to cache reconstructed u and v */                    \ | ||||
|   uint8_t uv_buf[14 * 32 + 15] = { 0 };                                        \ | ||||
|   uint8_t* const r_u = (uint8_t*)((uintptr_t)(uv_buf + 15) & ~15);             \ | ||||
|   uint8_t* const r_u = (uint8_t*)((uintptr_t)(uv_buf + 15) & ~(uintptr_t)15);  \ | ||||
|   uint8_t* const r_v = r_u + 32;                                               \ | ||||
|                                                                                \ | ||||
|   assert(top_y != NULL);                                                       \ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user