かなり新しいIntel HaswellプロセッサーからのAVX2命令を使用するプログラムをコンパイルしようとしています。
私が使用しているMacbook ProにはCrystalwellプロセッサが搭載されており、AVX2拡張機能が必要であることを確認しました。
sysctl -n machdep.cpu.brand_string
Intel(R) Core(TM) i7-4870HQ CPU @ 2.50GHz
私の意図は、Ubuntu 15.10 64ビットバージョンのVirtualBoxイメージを使用してそのようなプログラムをコンパイルすることです。これにはgccの最新バージョンが含まれています。
gcc (Ubuntu 5.2.1-22ubuntu2) 5.2.1 20151010
VirtualBoxマシンで拡張機能を確認しても、avx2がリストされていません。
processor : 3
vendor_id : GenuineIntel
cpu family : 6
model : 70
model name : Intel(R) Core(TM) i7-4870HQ CPU @ 2.50GHz
stepping : 1
cpu MHz : 2494.226
cache size : 6144 KB
physical id : 0
siblings : 4
core id : 3
cpu cores : 4
apicid : 3
initial apicid : 3
fpu : yes
fpu_exception : yes
cpuid level : 13
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall nx rdtscp lm constant_tsc rep_good nopl xtopology nonstop_tsc pni pclmulqdq ssse3 cx16 sse4_1 sse4_2 movbe popcnt aes xsave avx rdrand hypervisor lahf_lm abm
bugs :
bogomips : 4988.45
clflush size : 64
cache_alignment : 64
address sizes : 39 bits physical, 48 bits virtual
power management:
何か案は?
私は自分自身に同じ質問をしていました。 VirtualBoxのドキュメントの主要な部分を少し読んで、SSE4.1/SSE4.2は よく文書化されている ですが、AVX2はそうではないことを覚えています。 VirtualBox 5.0 Beta 。
14.04ホスト上の/ proc/cpuinfoのフラグは次のとおりです。
flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat
pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx
pdpe1gb rdtscp lm constant_tsc Arch_perfmon pebs bts rep_good nopl
xtopology nonstop_tsc aperfmperf eagerfpu pni pclmulqdq dtes64
monitor ds_cpl vmx est tm2 ssse3 fma cx16 xtpr pdcm pcid sse4_1
sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c
rdrand lahf_lm abm ida arat pln pts dtherm tpr_shadow vnmi
flexpriority ept vpid fsgsbase tsc_adjust bmi1 avx2 smep bmi2 erms
invpcid xsaveopt
virtualBox 5.0.14がホストするVM
flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat
pse36 clflush mmx fxsr sse sse2 ht syscall nx rdtscp lm
constant_tsc rep_good nopl xtopology nonstop_tsc pni pclmulqdq
ssse3 cx16 sse4_1 sse4_2 movbe popcnt aes xsave avx rdrand
hypervisor lahf_lm abm
インターネットを検索し、ソースをダウンロードしました。これにより、 this ticket wherefrank(Frank Mehnert、私が推測)AVXを無効にする方法と- このチケット 5.0.2の時点でAVX2パススルーを一時的に無効にする理由として、変更ログに記載されています。そのため、それを無効にする理由があり、注意する必要があります。
VBoxManage setextradata "$vm_name" VBoxInternal/CPUM/IsaExts/AVX2 1
を実行し、VMを起動し、AVX2を有効にしました:
flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat
pse36 clflush mmx fxsr sse sse2 ht syscall nx rdtscp lm
constant_tsc rep_good nopl xtopology nonstop_tsc pni pclmulqdq
ssse3 cx16 sse4_1 sse4_2 movbe popcnt aes xsave avx rdrand
hypervisor lahf_lm abm avx2
VMでx265を実行したことを確認するには:
x265 [info]: using cpu capabilities: MMX2 SSE2Fast SSSE3 SSE4.2 AVX AVX2 LZCNT
他の何かを有効にできるかどうか探していましたが、ソースのgrep -r -i "search_term" .
は、検索語pIsaExts
、pExtFeatureLeaf
、pFeatures
、pCurLeaf
、およびpCpumCfg
の結果を表示しましたが、キーを追加しても効果がなかったかVM開始を拒否しました。そういえば、設定したすべての追加キーを表示するには、次を実行します。
VBoxManage getextradata "$vm_name" enumerate
キーを削除するには、キーを設定したのと同じコマンドを実行しますが、値はありません。例:
VBoxManage setextradata "$vm_name" VBoxInternal/CPUM/IsaExts/AVX2
ソースをただ見回すのではなく、プロジェクトの ソースコードの構成 を読んで理解する方が良いでしょう。