文書の表示以前のリビジョンバックリンク全て展開する/折り畳む文書の先頭へ この文書は読取専用です。文書のソースを閲覧することは可能ですが、変更はできません。もし変更したい場合は管理者に連絡してください。 ====== FreeBSD 11.0RにしたらVirtualBoxが動かなくなった(´・ω・`) ====== 先日、家鯖をFreeBSD 11.0-RELEASEに更新してからVirtualBoxが動かなくなった。起動しようとすると''VirtualBox: supR3HardenedExecDir: sysctl failed''とエラーを吐いて終了する。sysctlに失敗するってどういうこっちゃ。 当該ソースは''SUPR3HardenedMain.cpp''の1243行目付近で、VirtualBox自身の実行ファイルパスを取得してる部分。 <code c> # else /* RT_OS_FREEBSD */ int aiName[4]; aiName[0] = CTL_KERN; aiName[1] = KERN_PROC; aiName[2] = KERN_PROC_PATHNAME; aiName[3] = getpid(); size_t cbPath = sizeof(g_szSupLibHardenedExePath); if (sysctl(aiName, RT_ELEMENTS(aiName), g_szSupLibHardenedExePath, &cbPath, NULL, 0) < 0) supR3HardenedFatal("supR3HardenedExecDir: sysctl failed\n"); g_szSupLibHardenedExePath[sizeof(g_szSupLibHardenedExePath) - 1] = '\0'; int cchLink = suplibHardenedStrLen(g_szSupLibHardenedExePath); /* paranoid? can't we use cbPath? */ # endif </code> 何の変哲もないコードだし、特に最近変わったような雰囲気もない。原因切り分けのため、上記コードと同じ事をする簡単なテストコードをでっちあげて実行してみたら、同じように失敗する。 <code c> #include <sys/param.h> #include <sys/sysctl.h> #include <stdio.h> int main(void) { int pid = getpid(); int mib[4] = { CTL_KERN, KERN_PROC, KERN_PROC_PATHNAME, pid }; printf("pid = %d\n", pid); size_t bufSize = 1024; char buf[bufSize]; int result = sysctl(mib, 4, buf, &bufSize, NULL, 0); if (result < 0) { perror("sysctl"); } return 0; } </code> <code> -------- 実行結果 -------- $ ./sysctltest pid = 66245 sysctl: No such file or directory </code> ''supR3HardenedExecDir''でググると[[https://lists.freebsd.org/pipermail/freebsd-ports/2009-June/055251.html|procfsをマウントし忘れてんじゃね?]]という投稿が出てくるが、今回の問題箇所は[[https://www.virtualbox.org/pipermail/vbox-dev/2009-December/007728.html|procfsを不要とするため]]の部分なのでprocfsをマウントしようがしまいが変わらない(大体今までprocfsマウントしてなくても動いてたし…)、と思いつつ藁をも掴む思いでマウントしてみたけど、やっぱり何の解決にもならなかった\(^o^)/ portsでソースからのインストールも試みたけどビルドがコケるし、もぅマヂ無理。リスカしょ…。 ===== 参考サイト ===== * [[https://lists.freebsd.org/pipermail/freebsd-ports/2009-June/055251.html|[Call For Testing] VirtualBox for FreeBSD!]] * [[https://www.virtualbox.org/pipermail/vbox-dev/2009-December/007728.html|[vbox-dev] [patch] FreeBSD without procfs]] * [[https://bompopo.wordpress.com/2009/11/02/virtualbox%E3%81%8C%E8%B5%B7%E5%8B%95%E3%81%97%E3%81%AA%E3%81%8B%E3%81%A3%E3%81%9F/|VirtualBoxが起動しなかった | サーバいじくり雑記]] blog/2016/2016-11-08.txt 最終更新: 2016-11-09 16:45by Decomo