[cvs] / xvidcore / src / image / qpel.c Repository:
ViewVC logotype

Diff of /xvidcore/src/image/qpel.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.6, Mon Jul 11 22:10:24 2005 UTC revision 1.9, Wed Nov 26 01:04:34 2008 UTC
# Line 25  Line 25 
25    
26  #ifndef XVID_AUTO_INCLUDE  #ifndef XVID_AUTO_INCLUDE
27    
28    #include <stdio.h>
29    
30  #include "../portab.h"  #include "../portab.h"
31  #include "qpel.h"  #include "qpel.h"
32    
# Line 197  Line 199 
199  /* Global scope hooks  /* Global scope hooks
200   ****************************************************************************/   ****************************************************************************/
201    
202  XVID_QP_FUNCS *xvid_QP_Funcs = 0;  XVID_QP_FUNCS *xvid_QP_Funcs = NULL;
203  XVID_QP_FUNCS *xvid_QP_Add_Funcs = 0;  XVID_QP_FUNCS *xvid_QP_Add_Funcs = NULL;
204    
205  /* Reference plain C impl. declaration  /* Reference plain C impl. declaration
206   ****************************************************************************/   ****************************************************************************/
# Line 241  Line 243 
243  /* mmx impl. declaration (see. qpel_mmx.asm  /* mmx impl. declaration (see. qpel_mmx.asm
244   ****************************************************************************/   ****************************************************************************/
245    
246  #ifdef ARCH_IS_IA32  #if defined (ARCH_IS_IA32) || defined(ARCH_IS_X86_64)
247  extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_16_mmx);  extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_16_mmx);
248  extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_16_mmx);  extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_16_mmx);
249  extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_Up_16_mmx);  extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_Up_16_mmx);
# Line 340  Line 342 
342    
343  #endif /* ARCH_IS_PPC */  #endif /* ARCH_IS_PPC */
344    
 /* mmx impl. (for 64bit bus) declaration (see. qpel_mmx.asm  
  ****************************************************************************/  
   
 #ifdef ARCH_IS_X86_64  
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_16_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_16_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_Up_16_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_16_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_Avrg_16_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_Avrg_Up_16_x86_64);  
   
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_8_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_8_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_Up_8_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_8_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_Avrg_8_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_Avrg_Up_8_x86_64);  
   
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Add_16_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_Add_16_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_Up_Add_16_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_Add_16_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_Avrg_Add_16_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_Avrg_Up_Add_16_x86_64);  
   
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_8_Add_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_8_Add_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_H_Pass_Avrg_Up_8_Add_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_8_Add_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_Avrg_8_Add_x86_64);  
 extern XVID_QP_PASS_SIGNATURE(xvid_V_Pass_Avrg_Up_8_Add_x86_64);  
   
 XVID_QP_FUNCS xvid_QP_Funcs_x86_64 = {  
         xvid_H_Pass_16_x86_64, xvid_H_Pass_Avrg_16_x86_64, xvid_H_Pass_Avrg_Up_16_x86_64,  
         xvid_V_Pass_16_x86_64, xvid_V_Pass_Avrg_16_x86_64, xvid_V_Pass_Avrg_Up_16_x86_64,  
   
         xvid_H_Pass_8_x86_64, xvid_H_Pass_Avrg_8_x86_64, xvid_H_Pass_Avrg_Up_8_x86_64,  
         xvid_V_Pass_8_x86_64, xvid_V_Pass_Avrg_8_x86_64, xvid_V_Pass_Avrg_Up_8_x86_64  
 };  
   
 XVID_QP_FUNCS xvid_QP_Add_Funcs_x86_64 = {  
         xvid_H_Pass_Add_16_x86_64, xvid_H_Pass_Avrg_Add_16_x86_64, xvid_H_Pass_Avrg_Up_Add_16_x86_64,  
         xvid_V_Pass_Add_16_x86_64, xvid_V_Pass_Avrg_Add_16_x86_64, xvid_V_Pass_Avrg_Up_Add_16_x86_64,  
   
         xvid_H_Pass_8_Add_x86_64, xvid_H_Pass_Avrg_8_Add_x86_64, xvid_H_Pass_Avrg_Up_8_Add_x86_64,  
         xvid_V_Pass_8_Add_x86_64, xvid_V_Pass_Avrg_8_Add_x86_64, xvid_V_Pass_Avrg_Up_8_Add_x86_64,  
 };  
 #endif /* ARCH_IS_X86_64 */  
   
345  /* tables for ASM  /* tables for ASM
346   ****************************************************************************/   ****************************************************************************/
347    
 #ifdef ARCH_IS_IA32  
 uint16_t xvid_Expand_mmx[256][4]; /* 8b -> 64b expansion table */  
 #endif  
348    
349  #ifdef ARCH_IS_X86_64  #if defined(ARCH_IS_IA32) || defined(ARCH_IS_X86_64)
350    /* These symbols will be used outside this file, so tell the compiler
351     * they're global. */
352  extern uint16_t xvid_Expand_mmx[256][4]; /* 8b -> 64b expansion table */  extern uint16_t xvid_Expand_mmx[256][4]; /* 8b -> 64b expansion table */
 #endif  
353    
 /* Alternate way of filtering (cf. USE_TABLES flag in qpel_mmx.asm)  
  *  
  * 17 tables, 2K each => 34K  
  * Mirroring can be acheived composing 11 basic tables  
  * (for instance: (23,19,-6,3)=(20,20,-6,3)+(3,-1,0,0)  
  * Using Symmetries (and bswap) could reduce further  
  * the memory to 7 tables (->14K). */  
 #ifdef ARCH_IS_X86_64  
354  extern int16_t xvid_FIR_1_0_0_0[256][4];  extern int16_t xvid_FIR_1_0_0_0[256][4];
355  extern int16_t xvid_FIR_3_1_0_0[256][4];  extern int16_t xvid_FIR_3_1_0_0[256][4];
356  extern int16_t xvid_FIR_6_3_1_0[256][4];  extern int16_t xvid_FIR_6_3_1_0[256][4];
# Line 425  Line 368 
368  extern int16_t xvid_FIR_0_1_3_6[256][4];  extern int16_t xvid_FIR_0_1_3_6[256][4];
369  extern int16_t xvid_FIR_0_0_1_3[256][4];  extern int16_t xvid_FIR_0_0_1_3[256][4];
370  extern int16_t xvid_FIR_0_0_0_1[256][4];  extern int16_t xvid_FIR_0_0_0_1[256][4];
371  #else  #endif
372  int16_t xvid_FIR_1_0_0_0[256][4];  
373  int16_t xvid_FIR_3_1_0_0[256][4];  /* Arrays definitions, according to the target platform */
374  int16_t xvid_FIR_6_3_1_0[256][4];  
375  int16_t xvid_FIR_14_3_2_1[256][4];  #if !defined(ARCH_IS_X86_64) && !defined(ARCH_IS_IA32)
376  int16_t xvid_FIR_20_6_3_1[256][4];  /* Only ia32/ia64 will use these tables outside this file so mark them
377  int16_t xvid_FIR_20_20_6_3[256][4];  * static for all other archs */
378  int16_t xvid_FIR_23_19_6_3[256][4];  #define __SCOPE static
379  int16_t xvid_FIR_7_20_20_6[256][4];  __SCOPE int16_t xvid_FIR_1_0_0_0[256][4];
380  int16_t xvid_FIR_6_20_20_6[256][4];  __SCOPE int16_t xvid_FIR_3_1_0_0[256][4];
381  int16_t xvid_FIR_6_20_20_7[256][4];  __SCOPE int16_t xvid_FIR_6_3_1_0[256][4];
382  int16_t xvid_FIR_3_6_20_20[256][4];  __SCOPE int16_t xvid_FIR_14_3_2_1[256][4];
383  int16_t xvid_FIR_3_6_19_23[256][4];  __SCOPE int16_t xvid_FIR_20_6_3_1[256][4];
384  int16_t xvid_FIR_1_3_6_20[256][4];  __SCOPE int16_t xvid_FIR_20_20_6_3[256][4];
385  int16_t xvid_FIR_1_2_3_14[256][4];  __SCOPE int16_t xvid_FIR_23_19_6_3[256][4];
386  int16_t xvid_FIR_0_1_3_6[256][4];  __SCOPE int16_t xvid_FIR_7_20_20_6[256][4];
387  int16_t xvid_FIR_0_0_1_3[256][4];  __SCOPE int16_t xvid_FIR_6_20_20_6[256][4];
388  int16_t xvid_FIR_0_0_0_1[256][4];  __SCOPE int16_t xvid_FIR_6_20_20_7[256][4];
389    __SCOPE int16_t xvid_FIR_3_6_20_20[256][4];
390    __SCOPE int16_t xvid_FIR_3_6_19_23[256][4];
391    __SCOPE int16_t xvid_FIR_1_3_6_20[256][4];
392    __SCOPE int16_t xvid_FIR_1_2_3_14[256][4];
393    __SCOPE int16_t xvid_FIR_0_1_3_6[256][4];
394    __SCOPE int16_t xvid_FIR_0_0_1_3[256][4];
395    __SCOPE int16_t xvid_FIR_0_0_0_1[256][4];
396  #endif  #endif
397    
398  static void Init_FIR_Table(int16_t Tab[][4],  static void Init_FIR_Table(int16_t Tab[][4],
# Line 458  Line 408 
408  }  }
409    
410    
411  void xvid_Init_QP()  void xvid_Init_QP(void)
412  {  {
413  #ifdef ARCH_IS_IA32  #if defined (ARCH_IS_IA32) || defined (ARCH_IS_X86_64)
414          int i;          int i;
415    
416          for(i=0; i<256; ++i) {          for(i=0; i<256; ++i) {

Legend:
Removed from v.1.6  
changed lines
  Added in v.1.9

No admin address has been configured
ViewVC Help
Powered by ViewVC 1.0.4