φ(・・*)ゞ ウーン
とりあえず仮想cpuのfpuのデータをセーブしたりフリーしたりするところのコンパイルエラーを通すように実装だん。基本的にBHyVeに必要な関数なのでvmm/以下にvmm_fpu.[ch]として作成しました。
uma_zcreateとかはDragonFly BSDだとsys/netgraph7/dragonfly.hでマクロとして定義しているのを見つけたのでそれを適当にコピりました。このファイルのインクルードだけで済めばホントは良かったんですが、objcache_create_mbacked()に渡す引数をちょっと変える必要があったりしたのでコピペになりました。特に調べたわけではないですが使い方からしてobjcache_create_mbacked()はスラブ・アロケーターなんですかね。
+MALLOC_DEFINE(M_FPU_SAVE_AREA, "fpu_save_area", "fpu_sava_area manager"); + +#define uma_zcreate(name, size, ctor, dtor, uminit, fini, align, flags) \ + objcache_create_mbacked(M_FPU_SAVE_AREA, size, \ + NULL, 0, \ + NULL, NULL, \ + NULL)
その他にsavefpuはFreeBSDでは構造体、DragonFlyでは共用体という差があったのと、uma_zcreateの2番目の引数はsavefpuのサイズで良さげだったのでマクロとして作ってみたりしてます。
+#define cpu_max_ext_state_size sizeof(union savefpu) +union savefpu * +fpu_save_area_alloc(void) +{ + if (fpu_save_area_zone == NULL) { + fpu_save_area_zone = uma_zcreate("FPU_save_area", + cpu_max_ext_state_size, + NULL, NULL, NULL, NULL, + XSAVE_AREA_ALIGN - 1, 0); + } + + return (uma_zalloc(fpu_save_area_zone, 0)); +}
そしてこれらの関数を宣言したヘッダファイルを作ってvmm.cでインクルードした結果がこれです。
-------------------------------------------------------------- >>> Kernel build for BHYVE started on Thu Jul 12 22:31:43 JST 2012 -------------------------------------------------------------- ===> BHYVE cd /usr/src/sys/config; PATH=/usr/obj/usr/src/ctools_x86_64_x86_64/usr/sbin:/usr/obj/usr/src/ctools_x86_64_x86_64/usr/bin:/usr/obj/usr/src/ctools_x86_64_x86_64/bin:/usr/obj/usr/src/ctools_x86_64_x86_64/usr/games:/usr/obj/usr/src/btools_x86_64/usr/sbin:/usr/obj/usr/src/btools_x86_64/usr/bin:/usr/obj/usr/src/btools_x86_64/bin:/usr/obj/usr/src/btools_x86_64/usr/games:/usr/pkg/bin config -d /usr/obj/usr/src/sys/BHYVE /usr/src/sys/config/BHYVE Kernel build directory is /usr/obj/usr/src/sys/BHYVE cd /usr/obj/usr/src/sys/BHYVE; MAKEOBJDIRPREFIX=/usr/obj/usr/src/world_x86_64 OBJTREE=/usr/obj MACHINE_ARCH=x86_64 MACHINE=x86_64 MACHINE_PLATFORM=pc64 OBJFORMAT_PATH=/usr/obj/usr/src/ctools_x86_64_x86_64 HOST_CCVER=gcc44 CCVER=gcc44 BINUTILSVER=binutils221 DESTDIR=/usr/obj/usr/src/world_x86_64 INSTALL="sh /usr/src/tools/install.sh" PATH=/usr/obj/usr/src/ctools_x86_64_x86_64/usr/sbin:/usr/obj/usr/src/ctools_x86_64_x86_64/usr/bin:/usr/obj/usr/src/ctools_x86_64_x86_64/bin:/usr/obj/usr/src/ctools_x86_64_x86_64/usr/games:/usr/obj/usr/src/btools_x86_64/usr/sbin:/usr/obj/usr/src/btools_x86_64/usr/bin:/usr/obj/usr/src/btools_x86_64/bin:/usr/obj/usr/src/btools_x86_64/usr/games:/usr/pkg/bin make KERNEL=kernel all cc -c -O -pipe -Wall -Wredundant-decls -Wnested-externs -Wstrict-prototypes -Wmissing-prototypes -Wpointer-arith -Winline -Wcast-qual -Wold-style-definition -std=c99 -Wold-style-declaration -g -nostdinc -I. -Iinclude -I/usr/src/sys -I/usr/src/sys/../include -I/usr/obj/usr/src/sys/BHYVE -I"/usr/src/sys/dev/acpica5" -I"/usr/src/sys/contrib/dev/acpica-unix/include" -I/usr/src/sys/dev/netif/ath/hal -I/usr/src/sys/dev/netif/ath/hal/ath_hal -D_KERNEL -include opt_global.h -finline-limit=8000 --param inline-unit-growth=100 --param large-function-growth=1000 -fno-common -ffreestanding -mpreferred-stack-boundary=4 -fno-stack-protector -mcmodel=kernel -mno-red-zone -mfpmath=387 -mno-mmx -mno-3dnow -mno-sse -mno-sse2 -mno-sse3 -mno-ssse3 -mno-sse4.1 -mno-sse4.2 -mno-sse4 -mno-sse4a -mno-sse5 -mno-abm -mno-aes -mno-avx -mno-pclmul -mno-popcnt -msoft-float -fno-asynchronous-unwind-tables -fno-omit-frame-pointer /usr/src/sys/platform/pc64/vmm/vmm.c -Werror /usr/src/sys/platform/pc64/vmm/vmm.c: In function 'vm_map_mmio': /usr/src/sys/platform/pc64/vmm/vmm.c:288: error: 'VM_MEMATTR_UNCACHEABLE' undeclared (first use in this function) /usr/src/sys/platform/pc64/vmm/vmm.c:288: error: (Each undeclared identifier is reported only once /usr/src/sys/platform/pc64/vmm/vmm.c:288: error: for each function it appears in.) /usr/src/sys/platform/pc64/vmm/vmm.c: In function 'vm_unmap_mmio': /usr/src/sys/platform/pc64/vmm/vmm.c:297: error: 'VM_MEMATTR_UNCACHEABLE' undeclared (first use in this function) /usr/src/sys/platform/pc64/vmm/vmm.c: In function 'vm_malloc': /usr/src/sys/platform/pc64/vmm/vmm.c:323: error: 'VM_MEMATTR_WRITE_BACK' undeclared (first use in this function) cc1: warnings being treated as errors /usr/src/sys/platform/pc64/vmm/vmm.c: In function 'vm_set_pinning': /usr/src/sys/platform/pc64/vmm/vmm.c:482: error: implicit declaration of function 'thread_lock' /usr/src/sys/platform/pc64/vmm/vmm.c:482: error: nested extern declaration of 'thread_lock' /usr/src/sys/platform/pc64/vmm/vmm.c:483: error: implicit declaration of function 'sched_unbind' /usr/src/sys/platform/pc64/vmm/vmm.c:483: error: nested extern declaration of 'sched_unbind' /usr/src/sys/platform/pc64/vmm/vmm.c:484: error: implicit declaration of function 'thread_unlock' /usr/src/sys/platform/pc64/vmm/vmm.c:484: error: nested extern declaration of 'thread_unlock' /usr/src/sys/platform/pc64/vmm/vmm.c:488: error: implicit declaration of function 'CPU_ABSENT' /usr/src/sys/platform/pc64/vmm/vmm.c:488: error: nested extern declaration of 'CPU_ABSENT' /usr/src/sys/platform/pc64/vmm/vmm.c:496: error: implicit declaration of function 'sched_bind' /usr/src/sys/platform/pc64/vmm/vmm.c:496: error: nested extern declaration of 'sched_bind' /usr/src/sys/platform/pc64/vmm/vmm.c: In function 'restore_guest_fpustate': /usr/src/sys/platform/pc64/vmm/vmm.c:508: error: implicit declaration of function 'fpuexit' /usr/src/sys/platform/pc64/vmm/vmm.c:508: error: nested extern declaration of 'fpuexit' /usr/src/sys/platform/pc64/vmm/vmm.c:509: error: implicit declaration of function 'stop_emulating' /usr/src/sys/platform/pc64/vmm/vmm.c:509: error: nested extern declaration of 'stop_emulating' /usr/src/sys/platform/pc64/vmm/vmm.c:510: error: implicit declaration of function 'fpurestore' /usr/src/sys/platform/pc64/vmm/vmm.c:510: error: nested extern declaration of 'fpurestore' /usr/src/sys/platform/pc64/vmm/vmm.c: In function 'save_guest_fpustate': /usr/src/sys/platform/pc64/vmm/vmm.c:517: error: implicit declaration of function 'fpusave' /usr/src/sys/platform/pc64/vmm/vmm.c:517: error: nested extern declaration of 'fpusave' /usr/src/sys/platform/pc64/vmm/vmm.c:518: error: implicit declaration of function 'start_emulating' /usr/src/sys/platform/pc64/vmm/vmm.c:518: error: nested extern declaration of 'start_emulating' /usr/src/sys/platform/pc64/vmm/vmm.c: In function 'vm_run': /usr/src/sys/platform/pc64/vmm/vmm.c:541: error: implicit declaration of function 'set_pcb_flags' /usr/src/sys/platform/pc64/vmm/vmm.c:541: error: nested extern declaration of 'set_pcb_flags' /usr/src/sys/platform/pc64/vmm/vmm.c:541: error: 'PCB_FULL_IRET' undeclared (first use in this function) /usr/src/sys/platform/pc64/vmm/vmm.c:543: error: 'curcpu' undeclared (first use in this function) *** Error code 1 Stop in /usr/obj/usr/src/sys/BHYVE. *** Error code 1 Stop in /usr/src. *** Error code 1 Stop in /usr/src.
昨日よりはエラーが減りましたねぇ。でも、fpurestore、fpuextとかfpu周りで足りない関数があるのでこれは今日と同じように作る必要ありですね。作るべき関数はこちらで見れば良いので何とかなる気はしますが(´ε`;)ウーン…
と言っても、あくまでもコンパイルエラーを何とかするというところの話だけですけどね。