49 #define SPA_TYPE_INTERFACE_CPU  SPA_TYPE_INFO_INTERFACE_BASE "CPU" 
   51 #define SPA_VERSION_CPU         0 
   55 #define SPA_CPU_FLAG_MMX                (1<<0)   
   56 #define SPA_CPU_FLAG_MMXEXT             (1<<1)   
   57 #define SPA_CPU_FLAG_3DNOW              (1<<2)   
   58 #define SPA_CPU_FLAG_SSE                (1<<3)   
   59 #define SPA_CPU_FLAG_SSE2               (1<<4)   
   60 #define SPA_CPU_FLAG_3DNOWEXT           (1<<5)   
   61 #define SPA_CPU_FLAG_SSE3               (1<<6)   
   62 #define SPA_CPU_FLAG_SSSE3              (1<<7)   
   63 #define SPA_CPU_FLAG_SSE41              (1<<8)   
   64 #define SPA_CPU_FLAG_SSE42              (1<<9)   
   65 #define SPA_CPU_FLAG_AESNI              (1<<10)  
   66 #define SPA_CPU_FLAG_AVX                (1<<11)  
   67 #define SPA_CPU_FLAG_XOP                (1<<12)  
   68 #define SPA_CPU_FLAG_FMA4               (1<<13)  
   69 #define SPA_CPU_FLAG_CMOV               (1<<14)  
   70 #define SPA_CPU_FLAG_AVX2               (1<<15)  
   71 #define SPA_CPU_FLAG_FMA3               (1<<16)  
   72 #define SPA_CPU_FLAG_BMI1               (1<<17)  
   73 #define SPA_CPU_FLAG_BMI2               (1<<18)  
   74 #define SPA_CPU_FLAG_AVX512             (1<<19)  
   75 #define SPA_CPU_FLAG_SLOW_UNALIGNED     (1<<20)  
   78 #define SPA_CPU_FLAG_ALTIVEC            (1<<0)   
   79 #define SPA_CPU_FLAG_VSX                (1<<1)   
   80 #define SPA_CPU_FLAG_POWER8             (1<<2)   
   83 #define SPA_CPU_FLAG_ARMV5TE            (1 << 0) 
   84 #define SPA_CPU_FLAG_ARMV6              (1 << 1) 
   85 #define SPA_CPU_FLAG_ARMV6T2            (1 << 2) 
   86 #define SPA_CPU_FLAG_VFP                (1 << 3) 
   87 #define SPA_CPU_FLAG_VFPV3              (1 << 4) 
   88 #define SPA_CPU_FLAG_NEON               (1 << 5) 
   89 #define SPA_CPU_FLAG_ARMV8              (1 << 6) 
   91 #define SPA_CPU_FORCE_AUTODETECT        ((uint32_t)-1) 
   93 #define SPA_CPU_VM_NONE                 (0) 
   94 #define SPA_CPU_VM_OTHER                (1 << 0) 
   95 #define SPA_CPU_VM_KVM                  (1 << 1) 
   96 #define SPA_CPU_VM_QEMU                 (1 << 2) 
   97 #define SPA_CPU_VM_BOCHS                (1 << 3) 
   98 #define SPA_CPU_VM_XEN                  (1 << 4) 
   99 #define SPA_CPU_VM_UML                  (1 << 5) 
  100 #define SPA_CPU_VM_VMWARE               (1 << 6) 
  101 #define SPA_CPU_VM_ORACLE               (1 << 7) 
  102 #define SPA_CPU_VM_MICROSOFT            (1 << 8) 
  103 #define SPA_CPU_VM_ZVM                  (1 << 9) 
  104 #define SPA_CPU_VM_PARALLELS            (1 << 10) 
  105 #define SPA_CPU_VM_BHYVE                (1 << 11) 
  106 #define SPA_CPU_VM_QNX                  (1 << 12) 
  107 #define SPA_CPU_VM_ACRN                 (1 << 13) 
  108 #define SPA_CPU_VM_POWERVM              (1 << 14) 
  116 #define SPA_VERSION_CPU_METHODS 2 
  139 #define spa_cpu_method(o,method,version,...)                            \ 
  141         int _res = -ENOTSUP;                                            \ 
  142         struct spa_cpu *_c = o;                                         \ 
  143         spa_interface_call_res(&_c->iface,                              \ 
  144                         struct spa_cpu_methods, _res,                   \ 
  145                         method, version, ##__VA_ARGS__);                \ 
  148 #define spa_cpu_get_flags(c)            spa_cpu_method(c, get_flags, 0) 
  149 #define spa_cpu_force_flags(c,f)        spa_cpu_method(c, force_flags, 0, f) 
  150 #define spa_cpu_get_count(c)            spa_cpu_method(c, get_count, 0) 
  151 #define spa_cpu_get_max_align(c)        spa_cpu_method(c, get_max_align, 0) 
  152 #define spa_cpu_get_vm_type(c)          spa_cpu_method(c, get_vm_type, 1) 
  153 #define spa_cpu_zero_denormals(c,e)     spa_cpu_method(c, zero_denormals, 2, e) 
  156 #define SPA_KEY_CPU_FORCE               "cpu.force"              
  157 #define SPA_KEY_CPU_VM_TYPE             "cpu.vm.type"            
  158 #define SPA_KEY_CPU_ZERO_DENORMALS      "cpu.zero.denormals"     
methods
Definition: cpu.h:168
 
uint32_t(* get_max_align)(void *object)
get maximum required alignment of data
Definition: cpu.h:185
 
int(* force_flags)(void *object, uint32_t flags)
force CPU flags, use SPA_CPU_FORCE_AUTODETECT to autodetect CPU flags
Definition: cpu.h:179
 
uint32_t(* get_count)(void *object)
get number of CPU cores
Definition: cpu.h:182
 
uint32_t(* get_flags)(void *object)
get CPU flags
Definition: cpu.h:176
 
int(* zero_denormals)(void *object, bool enable)
Definition: cpu.h:192
 
uint32_t(* get_vm_type)(void *object)
Definition: cpu.h:188
 
uint32_t version
Definition: cpu.h:173
 
struct spa_interface iface
Definition: cpu.h:59