diff options
-rw-r--r-- | emulators/qemu-devel/Makefile | 21 | ||||
-rw-r--r-- | emulators/qemu-devel/files/patch-cache-utils.c | 26 | ||||
-rw-r--r-- | emulators/qemu-devel/files/patch-cpu-exec.c | 35 | ||||
-rw-r--r-- | emulators/qemu-devel/files/patch-ppc.ld | 77 | ||||
-rw-r--r-- | emulators/qemu-devel/files/patch-tcg-ppc-tcg_target.h | 11 | ||||
-rw-r--r-- | emulators/qemu-devel/files/revert-fbsd-libmath-patch | 14 | ||||
-rw-r--r-- | emulators/qemu-devel/pkg-message | 286 | ||||
-rw-r--r-- | emulators/qemu/Makefile | 2 | ||||
-rw-r--r-- | emulators/qemu/pkg-message | 320 |
9 files changed, 514 insertions, 278 deletions
diff --git a/emulators/qemu-devel/Makefile b/emulators/qemu-devel/Makefile index 3bfabc12ae8c..06c30830fe44 100644 --- a/emulators/qemu-devel/Makefile +++ b/emulators/qemu-devel/Makefile @@ -7,7 +7,7 @@ PORTNAME= qemu PORTVERSION= 0.12.2 -PORTREVISION= 1 +PORTREVISION= 2 CATEGORIES= emulators MASTER_SITES= ${MASTER_SITE_SAVANNAH}:release \ ${MASTER_SITE_LOCAL}:snapshot \ @@ -26,7 +26,7 @@ USE_PERL5= yes PATCH_STRIP= -p1 MAKE_ENV+= BSD_MAKE="${MAKE}" LDFLAGS="${LDFLAGS}" MAN1= qemu.1 qemu-img.1 -ONLY_FOR_ARCHS= amd64 i386 +ONLY_FOR_ARCHS= amd64 i386 powerpc CONFLICTS= qemu-[0-9]* MAKE_JOBS_SAFE= yes @@ -87,12 +87,29 @@ BUILD_DEPENDS+= texi2html:${PORTSDIR}/textproc/texi2html MAKE_ARGS+= ARCH=x86_64 .endif +.if ${ARCH} == "powerpc" +MAKE_ARGS+= ARCH=ppc +.endif + pre-patch: @for A in ${ONLY_FOR_ARCHS}; do \ ${MKDIR} ${WRKSRC}/bsd/$$A; \ done post-patch: +.if ${ARCH} == "powerpc" +.if ${OSVERSION} < 800030 +# These OSVERSION don't have all the needed long double fns in their +# libc so just disable 80 bit floats completely. + @cd ${WRKSRC} && ${PATCH} --quiet -R ${PATCH_STRIP} < ${FILESDIR}/patch-libmath_FreeBSD-version + @cd ${WRKSRC} && ${PATCH} --quiet -R ${PATCH_STRIP} < ${FILESDIR}/patch-fbsd +.else +# ...else we only need to disable the libmath build. (since its +# x86-specific.) + @cd ${WRKSRC} && ${PATCH} --quiet < ${FILESDIR}/revert-fbsd-libmath-patch +.endif +.endif + .if defined(WITH_RTL8139_TIMER) @cd ${WRKSRC} && ${PATCH} --quiet < ${FILESDIR}/rtl8139-re-patch .endif diff --git a/emulators/qemu-devel/files/patch-cache-utils.c b/emulators/qemu-devel/files/patch-cache-utils.c new file mode 100644 index 000000000000..fee6ca6a929a --- /dev/null +++ b/emulators/qemu-devel/files/patch-cache-utils.c @@ -0,0 +1,26 @@ +--- a/cache-utils.c ++++ b/cache-utils.c +@@ -57,6 +57,23 @@ + } + #endif + ++#ifdef __FreeBSD__ ++#include <stdio.h> ++#include <sys/types.h> ++#include <sys/sysctl.h> ++ ++static void ppc_init_cacheline_sizes(void) ++{ ++ size_t len = 4; ++ unsigned cacheline; ++ ++ sysctlbyname ("machdep.cacheline_size", &cacheline, &len, NULL, 0); ++ ++ qemu_cache_conf.dcache_bsize = cacheline; ++ qemu_cache_conf.icache_bsize = cacheline; ++} ++#endif ++ + #ifdef __linux__ + void qemu_cache_utils_init(char **envp) + { diff --git a/emulators/qemu-devel/files/patch-cpu-exec.c b/emulators/qemu-devel/files/patch-cpu-exec.c new file mode 100644 index 000000000000..3c40fa38eb97 --- /dev/null +++ b/emulators/qemu-devel/files/patch-cpu-exec.c @@ -0,0 +1,35 @@ +--- a/cpu-exec.c ++++ b/cpu-exec.c +@@ -933,6 +933,20 @@ + # define TRAP_sig(context) REG_sig(trap, context) + #endif /* linux */ + ++#ifdef __FreeBSD__ ++#include <ucontext.h> ++# define IAR_sig(context) ((context)->uc_mcontext.mc_srr0) ++# define MSR_sig(context) ((context)->uc_mcontext.mc_srr1) ++# define CTR_sig(context) ((context)->uc_mcontext.mc_ctr) ++# define XER_sig(context) ((context)->uc_mcontext.mc_xer) ++# define LR_sig(context) ((context)->uc_mcontext.mc_lr) ++# define CR_sig(context) ((context)->uc_mcontext.mc_cr) ++/* Exception Registers access */ ++# define DAR_sig(context) ((context)->uc_mcontext.mc_dar) ++# define DSISR_sig(context) ((context)->uc_mcontext.mc_dsisr) ++# define TRAP_sig(context) ((context)->uc_mcontext.mc_exc) ++#endif /* __FreeBSD__ */ ++ + #ifdef __APPLE__ + # include <sys/ucontext.h> + typedef struct ucontext SIGCONTEXT; +@@ -962,7 +976,11 @@ + void *puc) + { + siginfo_t *info = pinfo; ++#if defined (__FreeBSD__) ++ ucontext_t *uc = puc; ++#else + struct ucontext *uc = puc; ++#endif + unsigned long pc; + int is_write; + diff --git a/emulators/qemu-devel/files/patch-ppc.ld b/emulators/qemu-devel/files/patch-ppc.ld new file mode 100644 index 000000000000..ea911953ab06 --- /dev/null +++ b/emulators/qemu-devel/files/patch-ppc.ld @@ -0,0 +1,77 @@ +--- a/ppc.ld ++++ b/ppc.ld +@@ -79,36 +79,34 @@ + } + .sbss2 : { *(.sbss2 .sbss2.* .gnu.linkonce.sb2.*) } + .eh_frame_hdr : { *(.eh_frame_hdr) } +- .eh_frame : ONLY_IF_RO { KEEP (*(.eh_frame)) } +- .gcc_except_table : ONLY_IF_RO { *(.gcc_except_table .gcc_except_table.*) } + /* Adjust the address for the data segment. We want to adjust up to + the same address within the page on the next page up. */ + . = ALIGN (0x10000) - ((0x10000 - .) & (0x10000 - 1)); . = DATA_SEGMENT_ALIGN (0x10000, 0x1000); + /* Exception handling */ +- .eh_frame : ONLY_IF_RW { KEEP (*(.eh_frame)) } +- .gcc_except_table : ONLY_IF_RW { *(.gcc_except_table .gcc_except_table.*) } ++ .eh_frame : { KEEP (*(.eh_frame)) } ++ .gcc_except_table : { *(.gcc_except_table .gcc_except_table.*) } + /* Thread Local Storage sections */ + .tdata : { *(.tdata .tdata.* .gnu.linkonce.td.*) } + .tbss : { *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon) } + .preinit_array : + { +- PROVIDE_HIDDEN (__preinit_array_start = .); ++ PROVIDE (__preinit_array_start = .); + KEEP (*(.preinit_array)) +- PROVIDE_HIDDEN (__preinit_array_end = .); ++ PROVIDE (__preinit_array_end = .); + } + .init_array : + { +- PROVIDE_HIDDEN (__init_array_start = .); ++ PROVIDE (__init_array_start = .); + KEEP (*(SORT(.init_array.*))) + KEEP (*(.init_array)) +- PROVIDE_HIDDEN (__init_array_end = .); ++ PROVIDE(__init_array_end = .); + } + .fini_array : + { +- PROVIDE_HIDDEN (__fini_array_start = .); ++ PROVIDE (__fini_array_start = .); + KEEP (*(.fini_array)) + KEEP (*(SORT(.fini_array.*))) +- PROVIDE_HIDDEN (__fini_array_end = .); ++ PROVIDE (__fini_array_end = .); + } + .ctors : + { +@@ -142,9 +140,8 @@ + .got1 : { *(.got1) } + .got2 : { *(.got2) } + .dynamic : { *(.dynamic) } +- .got : SPECIAL { *(.got) } +- . = DATA_SEGMENT_RELRO_END (0, .); +- .plt : SPECIAL { *(.plt) } ++ .got : { *(.got) } ++ .plt : { *(.plt) } + .data : + { + *(.data .data.* .gnu.linkonce.d.*) +@@ -152,7 +149,7 @@ + SORT(CONSTRUCTORS) + } + .data1 : { *(.data1) } +- .got : SPECIAL { *(.got) } ++ .got : { *(.got) } + /* We want the small data sections together, so single-instruction offsets + can access them all, and initialized data all before uninitialized, so + we can shorten the on-disk segment size. */ +@@ -171,7 +168,7 @@ + *(.scommon) + PROVIDE (__sbss_end = .); PROVIDE (___sbss_end = .); + } +- .plt : SPECIAL { *(.plt) } ++ .plt : { *(.plt) } + .bss : + { + *(.dynbss) diff --git a/emulators/qemu-devel/files/patch-tcg-ppc-tcg_target.h b/emulators/qemu-devel/files/patch-tcg-ppc-tcg_target.h new file mode 100644 index 000000000000..1816317ac330 --- /dev/null +++ b/emulators/qemu-devel/files/patch-tcg-ppc-tcg_target.h @@ -0,0 +1,11 @@ +--- a/tcg/ppc/tcg-target.h ++++ b/tcg/ppc/tcg-target.h +@@ -69,7 +69,7 @@ + #define TCG_TARGET_CALL_STACK_OFFSET 24 + #elif defined _AIX + #define TCG_TARGET_CALL_STACK_OFFSET 52 +-#elif defined __linux__ ++#elif defined __linux__ || defined __FreeBSD__ + #define TCG_TARGET_CALL_ALIGN_ARGS 1 + #define TCG_TARGET_CALL_STACK_OFFSET 8 + #else diff --git a/emulators/qemu-devel/files/revert-fbsd-libmath-patch b/emulators/qemu-devel/files/revert-fbsd-libmath-patch new file mode 100644 index 000000000000..d7adf8ddc743 --- /dev/null +++ b/emulators/qemu-devel/files/revert-fbsd-libmath-patch @@ -0,0 +1,14 @@ +--- Makefile.orig 2010-02-06 20:59:24.000000000 +0100 ++++ Makefile 2010-02-06 21:00:17.000000000 +0100 +@@ -62,10 +62,7 @@ + + -include config-all-devices.mak + +-build-all: $(DOCS) $(TOOLS) bsd/libmath.a recurse-all +- +-bsd/libmath.a: +- ( cd bsd ; unset MAKEFLAGS ; $(BSD_MAKE) CC=$(CC) ) ++build-all: $(DOCS) $(TOOLS) recurse-all + + config-host.h: config-host.h-timestamp + config-host.h-timestamp: config-host.mak diff --git a/emulators/qemu-devel/pkg-message b/emulators/qemu-devel/pkg-message index 72d1ec7945e5..c73c056be381 100644 --- a/emulators/qemu-devel/pkg-message +++ b/emulators/qemu-devel/pkg-message @@ -1,141 +1,169 @@ -==== -FreeBSD host notes: -- needs to run as root in order to use /dev/tap* networking (why?) -(actually RELENG_6 and above now has a sysctl net.link.tap.user_open -to allow users to use it too. don't forget to adjust device node -permissions in /etc/devfs.rules.) -- slirp (usermode networking) is fixed now in cvs, on FreeSBIE 1.0 guests -you still have to manually do: - echo nameserver 10.0.2.3 >/etc/resolv.conf -but i've been told that that's normal. (fixed on FreeSBIE 1.1.) -and you have to wait a bit for dhclient to do its thing; traffic to -address 10.0.2.2 is routed to 127.1 on the host. -- expect timer problems when guest kernel HZ is > hosts, -for example time sleep 1 takes 49 seconds and booting sleeps for -minutes at the acd0 probe with a FreeSBIE 1.0 guest, thats because -its kernel is built with HZ=5000, and FreeBSD's default is 100... -(no longer a problem with FreeSBIE 1.1.) The linux 2.6 kernel uses -1000 by default btw. (changed to 250 later, and recent linux kernels now -no longer have a fixed HZ, aka `tickless kernel'...) Enabling /dev/rtc -doesn't seem to help either (not included since it needs a patch to -emulators/rtc.) -- update: the above problem has gotten worse with FreeBSD guests -somewhere before 8.0, mainly since the kernel now usually wants -double or even quadruple number of timer irqs compared to HZ if it -detects an apic (and at least early versions of FreeBSD 8 had a bug that -essentially halved qemu's clock rate too); the only reason you usually -don't see symptoms of this with FreeBSD 8 guests is they automatically -reduce their HZ to 100 when running in a VM while the default for the -host kernel is still HZ=1000. workarounds: for i386 guests you can -disable the apic in the guest by setting +FreeBSD host notes +================== + +- Needs to run as root in order to use /dev/tap* networking (why?) (actually + RELENG_6 and above now has a sysctl net.link.tap.user_open to allow users to + use it too. Don't forget to adjust device node permissions in + /etc/devfs.rules.) + +- slirp (usermode networking) is fixed now in cvs, on FreeSBIE 1.0 guests you + still have to manually do: echo nameserver 10.0.2.3 >/etc/resolv.conf but + i've been told that that's normal. (fixed on FreeSBIE 1.1.) And you have + to wait a bit for dhclient to do its thing; traffic to address 10.0.2.2 is + routed to 127.1 on the host. + +- Expect timer problems when guest kernel HZ is > hosts, for example time + sleep 1 takes 49 seconds and booting sleeps for minutes at the acd0 probe + with a FreeSBIE 1.0 guest, thats because its kernel is built with HZ=5000, + and FreeBSD's default is 100... (no longer a problem with FreeSBIE 1.1.) + The linux 2.6 kernel uses 1000 by default btw. (changed to 250 later, and + recent linux kernels now no longer have a fixed HZ, aka `tickless + kernel'...) Enabling /dev/rtc doesn't seem to help either (not included + since it needs a patch to emulators/rtc.) + +- update: the above problem has gotten worse with FreeBSD guests somewhere + before 8.0, mainly since the kernel now usually wants double or even + quadruple number of timer irqs compared to HZ if it detects an apic (and at + least early versions of FreeBSD 8 had a bug that essentially halved qemu's + clock rate too); the only reason you usually don't see symptoms of this with + FreeBSD 8 guests is they automatically reduce their HZ to 100 when running + in a VM while the default for the host kernel is still HZ=1000. + workarounds: for i386 guests you can disable the apic in the guest by + setting + hint.apic.0.disabled=1 -in loader.conf(5) (or manually at the loader prompt), otherwise the -only thing you can do is either reduce the guest's HZ to, say, 100 -by setting e.g. + + in loader.conf(5) (or manually at the loader prompt), otherwise the only thing + you can do is either reduce the guest's HZ to, say, 100 by setting e.g. + kern.hz="100" -from the loader as above (which usually is a good idea in a VM anyway -and FreeBSD 8 now does it by itself as mentioned), or if that's not -possible increase the host's HZ to 2000 or even 4000 from the loader -in the same way. -- the -smb option (smb-export local dir to guest) needs the net/samba3 -port/package installed in addition to qemu. -- if you want to use usb devices connected to the host in the guest -(usb_add host:... monitor command; this doesn't work on FreeBSD 8 and --current atm because of the new usb stack - help updating the usb-bsd.c -code is more than welcome here!) you need to make sure the host isn't -claiming them, e.g. for umass devices (like memory sticks or external -harddrives) make sure umass isn't in the kernel (you can then still -load it as a kld when needed), also unless you are running qemu as -root you then need to fix permissions for /dev/ugen* device nodes: -if you are on 5.x or later (devfs) put a rule in /etc/devfs.rules, -activate it in /etc/rc.conf and run /etc/rc.d/devfs restart. -example devfs.rules: + + from the loader as above (which usually is a good idea in a VM anyway and + FreeBSD 8 now does by itself as mentioned), or if that's not possible + increase the host's HZ to 2000 or even 4000 from the loader in the same way. + +- The -smb option (smb-export local dir to guest) needs the net/samba3 + port/package installed in addition to qemu. + +- If you want to use usb devices connected to the host in the guest + (usb_add host:... monitor command; this doesn't work on FreeBSD 8 and + -current atm because of the new usb stack - help updating the usb-bsd.c code + is more than welcome here!) you need to make sure the host isn't claiming + them, e.g. for umass devices (like memory sticks or external harddrives) + make sure umass isn't in the kernel (you can then still load it as a kld + when needed), also unless you are running qemu as root you then need to fix + permissions for /dev/ugen* device nodes: if you are on 5.x or later (devfs) + put a rule in /etc/devfs.rules, activate it in /etc/rc.conf and run + /etc/rc.d/devfs restart. Example devfs.rules: + [ugen_ruleset=20] add path 'ugen*' mode 660 group operator -corresponding rc.conf line: + + corresponding rc.conf line: + devfs_system_ruleset="ugen_ruleset" -- still usb: since the hub is no longer attached to the uchi controller -and the wakeup mechanism, resume interrupt is not implemented yet linux -guests will suspend the bus, i.e. they wont see devices usb_add'ed after -its (linux') uhci module got loaded. workaround: either add devices -before linux loads the module or rmmod and modprobe it afterwards. -- to avoid panics or non-working re(4) nics with FreeBSD guests if you -use qemu -net nic,model=rtl8139 -net user or tap ... enable the emulated -rtl8139 timer by building the port with RTL8139_TIMER enabled. -(the rtl8139c+ that model=rtl8139 emulates needs less cpu than qemu's -default ne2k nic which is driven by ed(4), it has not been made default -only because it may not work with all guests yet. btw qemu now also can -emulate a few intel eepro100 and e1000 nics which seem to be a tad more -efficient even, and at least i82557b and e1000 work without tweaks for -FreeBSD guests - driven by fxp(4) and em(4) repectively - and Linux -guests too.) -- if you get repeated `atapi_poll called!' console messages with FreeBSD -guests or other weird cdrom problems then thats probably because the guest -has atapicam loaded, which for reasons still to be determined has problems -with qemu's now by default enabled cdrom dma. You can build the port with -CDROM_DMA disabled to disable it. -- if you build qemu wihout SDL and then get crashes running it try -passing it -nographic. This should probably be default in that case... -- perhaps it should be noted that if you want to use qemu with -m 512 -or larger on 6.x/i386 hosts you need to increase the kern.maxdsiz tunable -in loader.conf(5) since the default is 512 MB, and qemu needs memory for -itself also. (7.0 and up now use jemalloc which uses mmap(2) and -isn't affected by kern.maxdsiz anymore.) + +- Still usb: since the hub is no longer attached to the uchi controller and + the wakeup mechanism, resume interrupt is not implemented yet linux guests + will suspend the bus, i.e. they wont see devices usb_add'ed after its + (linux') uhci module got loaded. Workaround: either add devices before + linux loads the module or rmmod and modprobe it afterwards. + +- To avoid panics or non-working re(4) nics with FreeBSD guests if you use + qemu -net nic,model=rtl8139 -net user or tap ... enable the emulated rtl8139 + timer by building the port with RTL8139_TIMER enabled. (The rtl8139c+ that + model=rtl8139 emulates needs less cpu than qemu's default ne2k nic which is + driven by ed(4), it has not been made default only because it may not work + with all guests yet. Btw qemu now also can emulate a few intel eepro100 and + e1000 nics which seem to be a tad more efficient even, and at least i82557b + and e1000 work without tweaks for FreeBSD guests - driven by fxp(4) and + em(4) repectively - and Linux guests too.) + +- If you get repeated `atapi_poll called!' console messages with FreeBSD + guests or other weird cdrom problems then thats probably because the guest + has atapicam loaded, which for reasons still to be determined has problems + with qemu's now by default enabled cdrom dma. You can build the port with + CDROM_DMA disabled to disable it. + +- If you build qemu wihout SDL and then get crashes running it try passing it + -nographic. This should probably be default in that case... + +- Perhaps it should be noted that if you want to use qemu with -m 512 or + larger on 6.x/i386 hosts you need to increase the kern.maxdsiz tunable in + loader.conf(5) since the default is 512 MB, and qemu needs memory for itself + also. (7.0 and up now use jemalloc which uses mmap(2) and isn't affected by + kern.maxdsiz anymore.) + - qemu's network boot roms (-boot n) have a bug when bootfiles sizes are a -multiple of blksize, if this affects you (like with FreeBSD's /boot/pxeboot) -you can do like + multiple of blksize, if this affects you (like with FreeBSD's /boot/pxeboot) + you can do like + cp /boot/pxeboot pxeboot-qemu && chmod +w pxeboot-qemu && echo >>pxeboot-qemu -and then use pxeboot-qemu. Actually you need latest -stable or -current -btx code (from after 7.0 was released) because of the real mode boot problem, -so use at least pxeboot from there. And I just did that for the pxeboot -extracted out of + + and then use pxeboot-qemu. Actually you need latest -stable or -current btx + code (from after 7.0 was released) because of the real mode boot problem, so + use at least pxeboot from there. And I just did that for the pxeboot + extracted out of + ftp://ftp.freebsd.org/pub/FreeBSD/snapshots/200805/7.0-STABLE-200805-i386-bootonly.iso -and placed it here: + + and placed it here: + http://people.freebsd.org/~nox/qemu/pxeboot-qemu -- if you use slirp (usernet, the default) and want to mount nfs into the -guest and you are not running qemu as root, then mountd(8) on the exporting -box needs to be run with -n in order to accept requests from ports >= 1024. -- the new (optional) pcap code cannot talk to the host on 6.x because -the necessary bpf feature (BIOCFEEDBACK) hasn't (yet?) been merged there. -- (not FreeBSD-specific:) there have been reports of qcow2 corruption with -(at least) win2k guests on recent kvm (which uses similar qcow2 code than -qemu now, see this thread: + +- If you use slirp (usernet, the default) and want to mount nfs into the guest + and you are not running qemu as root, then mountd(8) on the exporting box + needs to be run with -n in order to accept requests from ports >= 1024. + +- The new (optional) pcap code cannot talk to the host on 6.x because the + necessary bpf feature (BIOCFEEDBACK) hasn't (yet?) been merged there. + +- (not FreeBSD-specific:) There have been reports of qcow2 corruption with (at + least) win2k guests on recent kvm (which uses similar qcow2 code than qemu + now, see this thread: + http://lists.gnu.org/archive/html/qemu-devel/2009-02/msg00713.html - -the consensus on that thread seems to be that qcow(2) code has always -been experimental and you should use raw images if you want reliability; -raw is also usually faster.) You should be able to migrate existing images -to raw using qemu-img(1)'s convert function; raw doesn't support advanced -features like snapshots tho. -[a few important qcow2 bugfixed have been committed in the meantime so -this _might_ be less of an issue now.] -- (also not FreeBSD-specific:) It is recommended to pass raw images using -the new -drive syntax, specifying format=raw explicitly in order to avoid -malicious guests being able to exploit the format autodetection thats -otherwise getting used. (Not that you should run malicious guests anyway, -but this eleminates at least a known attack vector.) -- qemu now has improved physical cdrom support, but there still is -at least one known problem: you need to have the guest eject the disc -if you want to change it/take it out, or otherwise the guest may continue -using state (like size) of the old disc. (You can also do like -`change ide1-cd0 /dev/acd0' in the monitor after taking out the disc -if a guest cannot eject it itself.) -- The default configuration location (qemu-ifup script etc.) has been -changed from /etc to PREFIX/etc (usually /usr/local/etc). Move your -files accordingly. -- The pcap code (-net nic... -net pcap,ifname=...) should work properly -now, with only one exception: Advanced features like TSO used on the host -interface can cause oversize packets which now do get truncated to avoid -confusing/panicing guests but of course still will cause retransmissions. -So if you see slow throughput and `pcap_send: packet size > ..., truncating' -messages on qemu's tty try disabling TSO etc on the host interface at least -while using pcap. + + the consensus on that thread seems to be that qcow(2) code has always been + experimental and you should use raw images if you want reliability; raw is + also usually faster.) You should be able to migrate existing images to raw + using qemu-img(1)'s convert function; raw doesn't support advanced features + like snapshots tho. [a few important qcow2 bugfixed have been committed in + the meantime so this _might_ be less of an issue now.] + +- (also not FreeBSD-specific:) It is recommended to pass raw images using the + new -drive syntax, specifying format=raw explicitly in order to avoid + malicious guests being able to exploit the format autodetection thats + otherwise getting used. (Not that you should run malicious guests anyway, + but this eleminates at least a known attack vector.) + +- qemu now has improved physical cdrom support, but still there still is at + least one known problem: you need to have the guest eject the disc if you + want to change it/take it out, or otherwise the guest may continue using + state (like size) of the old disc. (You can also do like `change ide1-cd0 + /dev/acd0' in the monitor after taking out the disc if a guest cannot eject + it itself.) + +- The default configuration location (qemu-ifup script etc.) has been changed + from /etc to PREFIX/etc (usually /usr/local/etc). Move your files + accordingly. + +- The pcap code (-net nic... -net pcap,ifname=...) should work properly now, + with only one exception: Advanced features like TSO used on the host + interface can cause oversize packets which now do get truncated to avoid + confusing/panicing guests but of course still will cause retransmissions. + So if you see slow throughput and `pcap_send: packet size > ..., truncating' + messages on qemu's tty try disabling TSO etc on the host interface at least + while using pcap. + - kqemu is no longer supported in qemu upstream after the 0.11 branch -was created, which means also not in this version. (Linux has moved -on to kvm now for qemu(-like) virtualization needs, so if you want qemu -to go faster and don't want to switch to virtualbox or stick to the older -emulators/qemu port which is at 0.11.1 atm and as such still supports -kqemu you should help getting the FreeBSD kvm port updated and -completed: + was created, which means also not in this version. (Linux has moved + on to kvm now for qemu(-like) virtualization needs, so if you want qemu + to go faster and don't want to switch to virtualbox or stick to the older + emulators/qemu port which is at 0.11.1 atm and as such still supports + kqemu you should help getting the FreeBSD kvm port updated and + completed: + http://wiki.freebsd.org/FabioChecconi/PortingLinuxKVMToFreeBSD -) -==== + + ) diff --git a/emulators/qemu/Makefile b/emulators/qemu/Makefile index 1e5f983ce338..9278dd1c89f8 100644 --- a/emulators/qemu/Makefile +++ b/emulators/qemu/Makefile @@ -7,7 +7,7 @@ PORTNAME= qemu PORTVERSION= 0.11.1 -PORTREVISION= 1 +PORTREVISION= 2 CATEGORIES= emulators MASTER_SITES= ${MASTER_SITE_SAVANNAH} \ http://bellard.org/qemu/ diff --git a/emulators/qemu/pkg-message b/emulators/qemu/pkg-message index 6e35e73f7698..64cdd9b427c2 100644 --- a/emulators/qemu/pkg-message +++ b/emulators/qemu/pkg-message @@ -1,158 +1,186 @@ -==== -FreeBSD host notes: -- needs to run as root in order to use /dev/tap* networking (why?) -(actually RELENG_6 and above now has a sysctl net.link.tap.user_open -to allow users to use it too. don't forget to adjust device node -permissions in /etc/devfs.rules.) -- slirp (usermode networking) is fixed now in cvs, on FreeSBIE 1.0 guests -you still have to manually do: - echo nameserver 10.0.2.3 >/etc/resolv.conf -but i've been told that that's normal. (fixed on FreeSBIE 1.1.) -and you have to wait a bit for dhclient to do its thing; traffic to -address 10.0.2.2 is routed to 127.1 on the host. -- expect timer problems when guest kernel HZ is > hosts, -for example time sleep 1 takes 49 seconds and booting sleeps for -minutes at the acd0 probe with a FreeSBIE 1.0 guest, thats because -its kernel is built with HZ=5000, and FreeBSD's default is 100... -(no longer a problem with FreeSBIE 1.1.) The linux 2.6 kernel uses -1000 by default btw. (changed to 250 later, and recent linux kernels now -no longer have a fixed HZ, aka `tickless kernel'...) Enabling /dev/rtc -doesn't seem to help either (not included since it needs a patch to -emulators/rtc.) -- update: the above problem has gotten worse with FreeBSD guests -somewhere before 8.0, mainly since the kernel now usually wants -double or even quadruple number of timer irqs compared to HZ if it -detects an apic (and at least early versions of FreeBSD 8 had a bug that -essentially halved qemu's clock rate too); the only reason you usually -don't see symptoms of this with FreeBSD 8 guests is they automatically -reduce their HZ to 100 when running in a VM while the default for the -host kernel is still HZ=1000. workarounds: for i386 guests you can -disable the apic in the guest by setting +FreeBSD host notes +================== + +- Needs to run as root in order to use /dev/tap* networking (why?) (actually + RELENG_6 and above now has a sysctl net.link.tap.user_open to allow users to + use it too. Don't forget to adjust device node permissions in + /etc/devfs.rules.) + +- slirp (usermode networking) is fixed now in cvs, on FreeSBIE 1.0 guests you + still have to manually do: echo nameserver 10.0.2.3 >/etc/resolv.conf but + i've been told that that's normal. (fixed on FreeSBIE 1.1.) And you have + to wait a bit for dhclient to do its thing; traffic to address 10.0.2.2 is + routed to 127.1 on the host. + +- Expect timer problems when guest kernel HZ is > hosts, for example time + sleep 1 takes 49 seconds and booting sleeps for minutes at the acd0 probe + with a FreeSBIE 1.0 guest, thats because its kernel is built with HZ=5000, + and FreeBSD's default is 100... (no longer a problem with FreeSBIE 1.1.) + The linux 2.6 kernel uses 1000 by default btw. (changed to 250 later, and + recent linux kernels now no longer have a fixed HZ, aka `tickless + kernel'...) Enabling /dev/rtc doesn't seem to help either (not included + since it needs a patch to emulators/rtc.) + +- update: the above problem has gotten worse with FreeBSD guests somewhere + before 8.0, mainly since the kernel now usually wants double or even + quadruple number of timer irqs compared to HZ if it detects an apic (and at + least early versions of FreeBSD 8 had a bug that essentially halved qemu's + clock rate too); the only reason you usually don't see symptoms of this with + FreeBSD 8 guests is they automatically reduce their HZ to 100 when running + in a VM while the default for the host kernel is still HZ=1000. + workarounds: for i386 guests you can disable the apic in the guest by + setting + hint.apic.0.disabled=1 -in loader.conf(5) (or manually at the loader prompt), otherwise the -only thing you can do is either reduce the guest's HZ to, say, 100 -by setting e.g. + + in loader.conf(5) (or manually at the loader prompt), otherwise the only thing + you can do is either reduce the guest's HZ to, say, 100 by setting e.g. + kern.hz="100" -from the loader as above (which usually is a good idea in a VM anyway -and FreeBSD 8 now does by itself as mentioned), or if that's not -possible increase the host's HZ to 2000 or even 4000 from the loader -in the same way. -- the -smb option (smb-export local dir to guest) needs the net/samba3 -port/package installed in addition to qemu. -- if you want to use usb devices connected to the host in the guest -(usb_add host:... monitor command; this doesn't work on FreeBSD 8 and --current atm because of the new usb stack - help updating the usb-bsd.c -code is more than welcome here!) you need to make sure the host isn't -claiming them, e.g. for umass devices (like memory sticks or external -harddrives) make sure umass isn't in the kernel (you can then still -load it as a kld when needed), also unless you are running qemu as -root you then need to fix permissions for /dev/ugen* device nodes: -if you are on 5.x or later (devfs) put a rule in /etc/devfs.rules, -activate it in /etc/rc.conf and run /etc/rc.d/devfs restart. -example devfs.rules: + + from the loader as above (which usually is a good idea in a VM anyway and + FreeBSD 8 now does by itself as mentioned), or if that's not possible + increase the host's HZ to 2000 or even 4000 from the loader in the same way. + +- The -smb option (smb-export local dir to guest) needs the net/samba3 + port/package installed in addition to qemu. + +- If you want to use usb devices connected to the host in the guest + (usb_add host:... monitor command; this doesn't work on FreeBSD 8 and + -current atm because of the new usb stack - help updating the usb-bsd.c code + is more than welcome here!) you need to make sure the host isn't claiming + them, e.g. for umass devices (like memory sticks or external harddrives) + make sure umass isn't in the kernel (you can then still load it as a kld + when needed), also unless you are running qemu as root you then need to fix + permissions for /dev/ugen* device nodes: if you are on 5.x or later (devfs) + put a rule in /etc/devfs.rules, activate it in /etc/rc.conf and run + /etc/rc.d/devfs restart. Example devfs.rules: + [ugen_ruleset=20] add path 'ugen*' mode 660 group operator -corresponding rc.conf line: + + corresponding rc.conf line: + devfs_system_ruleset="ugen_ruleset" -- still usb: since the hub is no longer attached to the uchi controller -and the wakeup mechanism, resume interrupt is not implemented yet linux -guests will suspend the bus, i.e. they wont see devices usb_add'ed after -its (linux') uhci module got loaded. workaround: either add devices -before linux loads the module or rmmod and modprobe it afterwards. -- to avoid panics or non-working re(4) nics with FreeBSD guests if you -use qemu -net nic,model=rtl8139 -net user or tap ... enable the emulated -rtl8139 timer by building the port with RTL8139_TIMER enabled. -(the rtl8139c+ that model=rtl8139 emulates needs less cpu than qemu's -default ne2k nic which is driven by ed(4), it has not been made default -only because it may not work with all guests yet. btw qemu now also can -emulate a few intel eepro100 and e1000 nics which seem to be a tad more -efficient even, and at least i82557b and e1000 work without tweaks for -FreeBSD guests - driven by fxp(4) and em(4) repectively - and Linux -guests too.) -- if you get repeated `atapi_poll called!' console messages with FreeBSD -guests or other weird cdrom problems then thats probably because the guest -has atapicam loaded, which for reasons still to be determined has problems -with qemu's now by default enabled cdrom dma. You can build the port with -CDROM_DMA disabled to disable it. -- if you build qemu wihout SDL and then get crashes running it try -passing it -nographic. This should probably be default in that case... -- perhaps it should be noted that if you want to use qemu with -m 512 -or larger on 6.x/i386 hosts you need to increase the kern.maxdsiz tunable -in loader.conf(5) since the default is 512 MB, and qemu needs memory for -itself also. (7.0 and up now use jemalloc which uses mmap(2) and -isn't affected by kern.maxdsiz anymore.) -- if you use kqemu make sure your kqemu.ko is always in sync with your -kernel (like with any kld installed outside of base), i.e. rebuild its -port whenever you update the kernel - especially if you are switching -branches or are following a -stable or even -current branch! -- you can enable autoloading of kqemu at boot by adding a line + +- Still usb: since the hub is no longer attached to the uchi controller and + the wakeup mechanism, resume interrupt is not implemented yet linux guests + will suspend the bus, i.e. they wont see devices usb_add'ed after its + (linux') uhci module got loaded. Workaround: either add devices before + linux loads the module or rmmod and modprobe it afterwards. + +- To avoid panics or non-working re(4) nics with FreeBSD guests if you use + qemu -net nic,model=rtl8139 -net user or tap ... enable the emulated rtl8139 + timer by building the port with RTL8139_TIMER enabled. (The rtl8139c+ that + model=rtl8139 emulates needs less cpu than qemu's default ne2k nic which is + driven by ed(4), it has not been made default only because it may not work + with all guests yet. Btw qemu now also can emulate a few intel eepro100 and + e1000 nics which seem to be a tad more efficient even, and at least i82557b + and e1000 work without tweaks for FreeBSD guests - driven by fxp(4) and + em(4) repectively - and Linux guests too.) + +- If you get repeated `atapi_poll called!' console messages with FreeBSD + guests or other weird cdrom problems then thats probably because the guest + has atapicam loaded, which for reasons still to be determined has problems + with qemu's now by default enabled cdrom dma. You can build the port with + CDROM_DMA disabled to disable it. + +- If you build qemu wihout SDL and then get crashes running it try passing it + -nographic. This should probably be default in that case... + +- Perhaps it should be noted that if you want to use qemu with -m 512 or + larger on 6.x/i386 hosts you need to increase the kern.maxdsiz tunable in + loader.conf(5) since the default is 512 MB, and qemu needs memory for itself + also. (7.0 and up now use jemalloc which uses mmap(2) and isn't affected by + kern.maxdsiz anymore.) + +- If you use kqemu make sure your kqemu.ko is always in sync with your kernel + (like with any kld installed outside of base), i.e. rebuild its port + whenever you update the kernel - especially if you are switching branches or + are following a -stable or even -current branch! + +- You can enable autoloading of kqemu at boot by adding a line + kqemu_enable=YES -to /etc/rc.conf -- kqemu liked to panic the host on amd64 SMP until before 1.3.0.p11_6 -(revision 1.25 of /usr/ports/emulators/kqemu-kmod/Makefile), so if your -host is such you might want to make sure your kqemu-kmod port is new enough. -(and don't forget to reload it...) + + to /etc/rc.conf + - qemu's network boot roms (-boot n) have a bug when bootfiles sizes are a -multiple of blksize, if this affects you (like with FreeBSD's /boot/pxeboot) -you can do like + multiple of blksize, if this affects you (like with FreeBSD's /boot/pxeboot) + you can do like + cp /boot/pxeboot pxeboot-qemu && chmod +w pxeboot-qemu && echo >>pxeboot-qemu -and then use pxeboot-qemu. Actually you need latest -stable or -current -btx code (from after 7.0 was released) because of the real mode boot problem, -so use at least pxeboot from there. And I just did that for the pxeboot -extracted out of + + and then use pxeboot-qemu. Actually you need latest -stable or -current btx + code (from after 7.0 was released) because of the real mode boot problem, so + use at least pxeboot from there. And I just did that for the pxeboot + extracted out of + ftp://ftp.freebsd.org/pub/FreeBSD/snapshots/200805/7.0-STABLE-200805-i386-bootonly.iso -and placed it here: + + and placed it here: + http://people.freebsd.org/~nox/qemu/pxeboot-qemu -- if you use slirp (usernet, the default) and want to mount nfs into the -guest and you are not running qemu as root, then mountd(8) on the exporting -box needs to be run with -n in order to accept requests from ports >= 1024. -- unfortunately there can still be guests that don't run correctly with -kqemu and -kernel-kqemu especially on amd64 - not much you can do about that -other than help debugging (k)qemu... (well or falling back to unaccellerated -qemu/using only -enable-kqemu if its that what's causing the problems. -note however that kqemu now can also be used with the 32 bit qemu even -on amd64 hosts as of the 20080620 update.) -- the new (optional) pcap code cannot talk to the host on 6.x because -the necessary bpf feature (BIOCFEEDBACK) hasn't (yet?) been merged there. + +- If you use slirp (usernet, the default) and want to mount nfs into the guest + and you are not running qemu as root, then mountd(8) on the exporting box + needs to be run with -n in order to accept requests from ports >= 1024. + +- Unfortunately there can still be guests that don't run correctly with kqemu + and -kernel-kqemu especially on amd64 - not much you can do about that other + than help debugging (k)qemu... (well or falling back to unaccellerated + qemu/using only -enable-kqemu if its that what's causing the problems. note + however that kqemu now can also be used with the 32 bit qemu even on amd64 + hosts as of the 20080620 update.) + +- The new (optional) pcap code cannot talk to the host on 6.x because the + necessary bpf feature (BIOCFEEDBACK) hasn't (yet?) been merged there. + - kqemu passes the host tsc to the guest as-is so depending on your cpu and -guest you _may_ need to tell the guest to avoid relying on the tsc (notsc -kernel parameter with linux), or if that doesn't work force qemu onto -a single cpu by doing e.g. `cpuset -l 0 qemu ..' (see the cpuset(1) manpage -for details; cpuset isn't avalable before 7.1. This can only be a problem -on smp hosts.) -- (not FreeBSD-specific:) there have been reports of qcow2 corruption with -(at least) win2k guests on recent kvm (which uses similar qcow2 code than -qemu now, see this thread: + guest you _may_ need to tell the guest to avoid relying on the tsc (notsc + kernel parameter with linux), or if that doesn't work force qemu onto a + single cpu by doing e.g. `cpuset -l 0 qemu ..' (see the cpuset(1) manpage + for details; cpuset isn't avalable before 7.1. This can only be a problem + on smp hosts.) + +- (not FreeBSD-specific:) There have been reports of qcow2 corruption with (at + least) win2k guests on recent kvm (which uses similar qcow2 code than qemu + now, see this thread: + http://lists.gnu.org/archive/html/qemu-devel/2009-02/msg00713.html - -the consensus on that thread seems to be that qcow(2) code has always -been experimental and you should use raw images if you want reliability; -raw is also usually faster.) You should be able to migrate existing images -to raw using qemu-img(1)'s convert function; raw doesn't support advanced -features like snapshots tho. -[a few important qcow2 bugfixed have been committed in the meantime so -this _might_ be less of an issue now.] -- (also not FreeBSD-specific:) It is recommended to pass raw images using -the new -drive syntax, specifying format=raw explicitly in order to avoid -malicious guests being able to exploit the format autodetection thats -otherwise getting used. (Not that you should run malicious guests anyway, -but this eleminates at least a known attack vector.) -- qemu now has improved physical cdrom support, but still there still -is at least one known problem: you need to have the guest eject the disc -if you want to change it/take it out, or otherwise the guest may continue -using state (like size) of the old disc. (You can also do like -`change ide1-cd0 /dev/acd0' in the monitor after taking out the disc -if a guest cannot eject it itself.) -- The default configuration location (qemu-ifup script etc.) has been -changed from /etc to PREFIX/etc (usually /usr/local/etc). Move your -files accordingly. -- The pcap code (-net nic... -net pcap,ifname=...) should work properly -now, with only one exception: Advanced features like TSO used on the host -interface can cause oversize packets which now do get truncated to avoid -confusing/panicing guests but of course still will cause retransmissions. -So if you see slow throughput and `pcap_send: packet size > ..., truncating' -messages on qemu's tty try disabling TSO etc on the host interface at least -while using pcap. -- kqemu still works in the 0.11 branch, but is disabled by default now -so you'll have to pass -enable-kqemu (or -kernel-kqemu as with the -previous versions) if you want to use it. -==== + + the consensus on that thread seems to be that qcow(2) code has always been + experimental and you should use raw images if you want reliability; raw is + also usually faster.) You should be able to migrate existing images to raw + using qemu-img(1)'s convert function; raw doesn't support advanced features + like snapshots tho. [a few important qcow2 bugfixed have been committed in + the meantime so this _might_ be less of an issue now.] + +- (also not FreeBSD-specific:) It is recommended to pass raw images using the + new -drive syntax, specifying format=raw explicitly in order to avoid + malicious guests being able to exploit the format autodetection thats + otherwise getting used. (Not that you should run malicious guests anyway, + but this eleminates at least a known attack vector.) + +- qemu now has improved physical cdrom support, but still there still is at + least one known problem: you need to have the guest eject the disc if you + want to change it/take it out, or otherwise the guest may continue using + state (like size) of the old disc. (You can also do like `change ide1-cd0 + /dev/acd0' in the monitor after taking out the disc if a guest cannot eject + it itself.) + +- The default configuration location (qemu-ifup script etc.) has been changed + from /etc to PREFIX/etc (usually /usr/local/etc). Move your files + accordingly. + +- The pcap code (-net nic... -net pcap,ifname=...) should work properly now, + with only one exception: Advanced features like TSO used on the host + interface can cause oversize packets which now do get truncated to avoid + confusing/panicing guests but of course still will cause retransmissions. + So if you see slow throughput and `pcap_send: packet size > ..., truncating' + messages on qemu's tty try disabling TSO etc on the host interface at least + while using pcap. + +- kqemu still works in the 0.11 branch, but is disabled by default now so + you'll have to pass -enable-kqemu (or -kernel-kqemu as with the previous + versions) if you want to use it. |