svn commit: r223698 - in projects/bhyve: . bin/rcp bin/realpath bin/sh cddl/contrib/opensolaris/cmd/zfs cddl/contrib/opensolaris/lib/libzfs/common contrib/binutils/gas/config contrib/libpcap/bpf/ne...

Peter Grehan grehan at FreeBSD.org
Thu Jun 30 17:37:43 UTC 2011


Author: grehan
Date: Thu Jun 30 17:37:42 2011
New Revision: 223698
URL: http://svn.freebsd.org/changeset/base/223698

Log:
  IFC @ r223696 to pick up dfr's userboot

Added:
  projects/bhyve/etc/devd/usb.conf
     - copied unchanged from r223696, head/etc/devd/usb.conf
  projects/bhyve/lib/libusb/libusb01.c
     - copied unchanged from r223696, head/lib/libusb/libusb01.c
  projects/bhyve/sys/boot/common/disk.c
     - copied unchanged from r223696, head/sys/boot/common/disk.c
  projects/bhyve/sys/boot/common/disk.h
     - copied unchanged from r223696, head/sys/boot/common/disk.h
  projects/bhyve/sys/boot/ficl/amd64/
     - copied from r223696, head/sys/boot/ficl/amd64/
  projects/bhyve/sys/boot/userboot/
     - copied from r223696, head/sys/boot/userboot/
  projects/bhyve/sys/contrib/pf/net/if_pflow.h
     - copied unchanged from r223696, head/sys/contrib/pf/net/if_pflow.h
  projects/bhyve/sys/contrib/pf/net/pf_lb.c
     - copied unchanged from r223696, head/sys/contrib/pf/net/pf_lb.c
  projects/bhyve/sys/dev/pci/pci_subr.c
     - copied unchanged from r223696, head/sys/dev/pci/pci_subr.c
  projects/bhyve/sys/dev/usb/template/usb_template_audio.c
     - copied unchanged from r223696, head/sys/dev/usb/template/usb_template_audio.c
  projects/bhyve/sys/dev/usb/template/usb_template_kbd.c
     - copied unchanged from r223696, head/sys/dev/usb/template/usb_template_kbd.c
  projects/bhyve/sys/dev/usb/template/usb_template_modem.c
     - copied unchanged from r223696, head/sys/dev/usb/template/usb_template_modem.c
  projects/bhyve/sys/dev/usb/template/usb_template_mouse.c
     - copied unchanged from r223696, head/sys/dev/usb/template/usb_template_mouse.c
  projects/bhyve/sys/modules/pfsync/
     - copied from r223696, head/sys/modules/pfsync/
  projects/bhyve/sys/x86/include/pci_cfgreg.h
     - copied unchanged from r223696, head/sys/x86/include/pci_cfgreg.h
  projects/bhyve/sys/x86/pci/pci_bus.c
     - copied unchanged from r223696, head/sys/x86/pci/pci_bus.c
  projects/bhyve/tools/regression/bin/sh/builtins/case10.0
     - copied unchanged from r223696, head/tools/regression/bin/sh/builtins/case10.0
  projects/bhyve/tools/tools/bus_autoconf/
     - copied from r223696, head/tools/tools/bus_autoconf/
Deleted:
  projects/bhyve/lib/libusb/libusb20_compat01.c
  projects/bhyve/sys/amd64/pci/pci_bus.c
  projects/bhyve/sys/contrib/pf/net/pf_subr.c
  projects/bhyve/sys/i386/pci/pci_bus.c
  projects/bhyve/usr.bin/calendar/calendars/ru_RU.KOI8-R/calendar.msk
Modified:
  projects/bhyve/UPDATING
  projects/bhyve/bin/rcp/rcp.c
  projects/bhyve/bin/realpath/realpath.1
  projects/bhyve/bin/realpath/realpath.c
  projects/bhyve/bin/sh/arith_yacc.c
  projects/bhyve/bin/sh/mkinit.c
  projects/bhyve/bin/sh/sh.1
  projects/bhyve/cddl/contrib/opensolaris/cmd/zfs/zfs.8
  projects/bhyve/cddl/contrib/opensolaris/cmd/zfs/zfs_main.c
  projects/bhyve/cddl/contrib/opensolaris/lib/libzfs/common/libzfs_dataset.c
  projects/bhyve/contrib/binutils/gas/config/tc-arm.c
  projects/bhyve/contrib/libpcap/bpf/net/bpf_filter.c
  projects/bhyve/contrib/ntp/ntpd/ntp_config.c
  projects/bhyve/contrib/ntp/ntpd/ntp_intres.c
  projects/bhyve/contrib/ntp/ntpd/ntp_io.c
  projects/bhyve/contrib/pf/authpf/authpf.8
  projects/bhyve/contrib/pf/authpf/authpf.c
  projects/bhyve/contrib/pf/authpf/pathnames.h
  projects/bhyve/contrib/pf/ftp-proxy/filter.c
  projects/bhyve/contrib/pf/ftp-proxy/filter.h
  projects/bhyve/contrib/pf/ftp-proxy/ftp-proxy.8
  projects/bhyve/contrib/pf/ftp-proxy/ftp-proxy.c
  projects/bhyve/contrib/pf/man/pf.4
  projects/bhyve/contrib/pf/man/pf.conf.5
  projects/bhyve/contrib/pf/man/pf.os.5
  projects/bhyve/contrib/pf/man/pflog.4
  projects/bhyve/contrib/pf/man/pfsync.4
  projects/bhyve/contrib/pf/pfctl/parse.y
  projects/bhyve/contrib/pf/pfctl/pf_print_state.c
  projects/bhyve/contrib/pf/pfctl/pfctl.8
  projects/bhyve/contrib/pf/pfctl/pfctl.c
  projects/bhyve/contrib/pf/pfctl/pfctl.h
  projects/bhyve/contrib/pf/pfctl/pfctl_altq.c
  projects/bhyve/contrib/pf/pfctl/pfctl_optimize.c
  projects/bhyve/contrib/pf/pfctl/pfctl_osfp.c
  projects/bhyve/contrib/pf/pfctl/pfctl_parser.c
  projects/bhyve/contrib/pf/pfctl/pfctl_parser.h
  projects/bhyve/contrib/pf/pfctl/pfctl_qstats.c
  projects/bhyve/contrib/pf/pfctl/pfctl_radix.c
  projects/bhyve/contrib/pf/pfctl/pfctl_table.c
  projects/bhyve/contrib/pf/pflogd/pflogd.8
  projects/bhyve/contrib/pf/pflogd/pflogd.c
  projects/bhyve/contrib/pf/pflogd/privsep.c
  projects/bhyve/contrib/pf/pflogd/privsep_fdpass.c
  projects/bhyve/contrib/traceroute/traceroute.c
  projects/bhyve/contrib/tzdata/antarctica
  projects/bhyve/contrib/tzdata/asia
  projects/bhyve/contrib/tzdata/europe
  projects/bhyve/contrib/tzdata/southamerica
  projects/bhyve/contrib/tzdata/zone.tab
  projects/bhyve/etc/devd/Makefile
  projects/bhyve/etc/devd/uath.conf
  projects/bhyve/etc/network.subr
  projects/bhyve/etc/rc.d/netwait
  projects/bhyve/etc/rc.d/quota
  projects/bhyve/etc/regdomain.xml
  projects/bhyve/kerberos5/Makefile
  projects/bhyve/lib/csu/powerpc64/Makefile
  projects/bhyve/lib/libc/gen/getutxent.3
  projects/bhyve/lib/libc/gen/posix_spawn.3
  projects/bhyve/lib/libc/gen/posix_spawn.c
  projects/bhyve/lib/libc/gen/pututxline.c
  projects/bhyve/lib/libc/stdlib/malloc.c
  projects/bhyve/lib/libc/stdlib/ptsname.c
  projects/bhyve/lib/libmd/sha256.3
  projects/bhyve/lib/libmd/sha512.3
  projects/bhyve/lib/libprocstat/Makefile
  projects/bhyve/lib/libstand/tftp.c
  projects/bhyve/lib/libusb/Makefile
  projects/bhyve/lib/libusb/libusb10.c
  projects/bhyve/lib/libusb/libusb20.3
  projects/bhyve/lib/libusb/libusb20.c
  projects/bhyve/lib/libusb/libusb20.h
  projects/bhyve/lib/libusb/libusb20_int.h
  projects/bhyve/lib/libusb/libusb20_ugen20.c
  projects/bhyve/libexec/ftpd/ftpd.c
  projects/bhyve/libexec/tftpd/tftp-file.c
  projects/bhyve/libexec/tftpd/tftpd.8
  projects/bhyve/libexec/ulog-helper/Makefile
  projects/bhyve/libexec/ulog-helper/ulog-helper.c
  projects/bhyve/release/doc/en_US.ISO8859-1/readme/article.sgml
  projects/bhyve/release/doc/share/sgml/release.ent
  projects/bhyve/sbin/fsck_ffs/suj.c
  projects/bhyve/sbin/geom/class/part/geom_part.c
  projects/bhyve/sbin/growfs/growfs.8
  projects/bhyve/sbin/growfs/growfs.c
  projects/bhyve/sbin/hastctl/Makefile
  projects/bhyve/sbin/hastd/Makefile
  projects/bhyve/sbin/hastd/activemap.c
  projects/bhyve/sbin/hastd/primary.c
  projects/bhyve/sbin/hastd/subr.c
  projects/bhyve/sbin/ipfw/ipfw.8
  projects/bhyve/sbin/ipfw/ipfw2.c
  projects/bhyve/sbin/ipfw/ipfw2.h
  projects/bhyve/sbin/ipfw/main.c
  projects/bhyve/sbin/ipfw/nat.c
  projects/bhyve/sbin/newfs/newfs.8
  projects/bhyve/sbin/pflogd/Makefile
  projects/bhyve/sbin/savecore/savecore.c
  projects/bhyve/sbin/tunefs/tunefs.8
  projects/bhyve/share/man/man4/jme.4
  projects/bhyve/share/man/man4/ng_ether.4
  projects/bhyve/share/misc/iso3166
  projects/bhyve/share/mk/bsd.own.mk
  projects/bhyve/sys/amd64/amd64/pmap.c
  projects/bhyve/sys/amd64/amd64/sys_machdep.c
  projects/bhyve/sys/amd64/include/pci_cfgreg.h
  projects/bhyve/sys/arm/arm/pmap.c
  projects/bhyve/sys/arm/arm/sys_machdep.c
  projects/bhyve/sys/arm/at91/at91_machdep.c
  projects/bhyve/sys/arm/conf/CAMBRIA
  projects/bhyve/sys/arm/mv/common.c
  projects/bhyve/sys/arm/sa11x0/assabet_machdep.c
  projects/bhyve/sys/arm/sa11x0/sa11x0.c
  projects/bhyve/sys/boot/Makefile
  projects/bhyve/sys/boot/Makefile.amd64
  projects/bhyve/sys/boot/Makefile.arm
  projects/bhyve/sys/boot/Makefile.powerpc
  projects/bhyve/sys/boot/common/Makefile.inc
  projects/bhyve/sys/boot/common/load_elf.c
  projects/bhyve/sys/boot/common/reloc_elf.c
  projects/bhyve/sys/boot/i386/libi386/bioscd.c
  projects/bhyve/sys/boot/i386/zfsboot/zfsldr.S
  projects/bhyve/sys/cam/ata/ata_xpt.c
  projects/bhyve/sys/cam/cam_xpt.c
  projects/bhyve/sys/cam/scsi/scsi_cd.c
  projects/bhyve/sys/cam/scsi/scsi_xpt.c
  projects/bhyve/sys/cddl/contrib/opensolaris/common/zfs/zfs_prop.c
  projects/bhyve/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_dataset.c
  projects/bhyve/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/vdev_cache.c
  projects/bhyve/sys/cddl/contrib/opensolaris/uts/common/sys/fs/zfs.h
  projects/bhyve/sys/conf/NOTES
  projects/bhyve/sys/conf/files
  projects/bhyve/sys/conf/files.amd64
  projects/bhyve/sys/conf/files.i386
  projects/bhyve/sys/conf/files.ia64
  projects/bhyve/sys/conf/files.pc98
  projects/bhyve/sys/conf/options
  projects/bhyve/sys/contrib/altq/altq/altq_red.c
  projects/bhyve/sys/contrib/pf/net/if_pflog.c
  projects/bhyve/sys/contrib/pf/net/if_pflog.h
  projects/bhyve/sys/contrib/pf/net/if_pfsync.c
  projects/bhyve/sys/contrib/pf/net/if_pfsync.h
  projects/bhyve/sys/contrib/pf/net/pf.c
  projects/bhyve/sys/contrib/pf/net/pf_if.c
  projects/bhyve/sys/contrib/pf/net/pf_ioctl.c
  projects/bhyve/sys/contrib/pf/net/pf_mtag.h
  projects/bhyve/sys/contrib/pf/net/pf_norm.c
  projects/bhyve/sys/contrib/pf/net/pf_osfp.c
  projects/bhyve/sys/contrib/pf/net/pf_ruleset.c
  projects/bhyve/sys/contrib/pf/net/pf_table.c
  projects/bhyve/sys/contrib/pf/net/pfvar.h
  projects/bhyve/sys/dev/acpica/acpi.c
  projects/bhyve/sys/dev/acpica/acpi_cpu.c
  projects/bhyve/sys/dev/acpica/acpi_pcib_acpi.c
  projects/bhyve/sys/dev/acpica/acpi_resource.c
  projects/bhyve/sys/dev/acpica/acpi_thermal.c
  projects/bhyve/sys/dev/acpica/acpivar.h
  projects/bhyve/sys/dev/an/if_an.c
  projects/bhyve/sys/dev/ath/ah_osdep.c
  projects/bhyve/sys/dev/ath/ath_hal/ah.h
  projects/bhyve/sys/dev/ath/ath_hal/ah_eeprom_9287.h
  projects/bhyve/sys/dev/ath/ath_hal/ah_internal.h
  projects/bhyve/sys/dev/ath/ath_hal/ah_regdomain.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5210/ar5210_attach.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5210/ar5210_beacon.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5211/ar5211_attach.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5211/ar5211_beacon.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5211/ar5211_xmit.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5212/ar5112.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5212/ar5212_attach.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5212/ar5212_beacon.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5212/ar5212_xmit.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5312/ar5312_attach.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5416/ar2133.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5416/ar5416_attach.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5416/ar5416_beacon.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5416/ar5416_misc.c
  projects/bhyve/sys/dev/ath/ath_hal/ar5416/ar5416_xmit.c
  projects/bhyve/sys/dev/ath/ath_hal/ar9001/ar9130_attach.c
  projects/bhyve/sys/dev/ath/ath_hal/ar9001/ar9160_attach.c
  projects/bhyve/sys/dev/ath/ath_hal/ar9002/ar9280_attach.c
  projects/bhyve/sys/dev/ath/ath_hal/ar9002/ar9285_attach.c
  projects/bhyve/sys/dev/ath/ath_hal/ar9002/ar9287_attach.c
  projects/bhyve/sys/dev/ath/if_ath.c
  projects/bhyve/sys/dev/ath/if_ath_sysctl.c
  projects/bhyve/sys/dev/ath/if_ath_sysctl.h
  projects/bhyve/sys/dev/cardbus/cardbus_cis.c
  projects/bhyve/sys/dev/dc/dcphy.c
  projects/bhyve/sys/dev/dc/if_dc.c
  projects/bhyve/sys/dev/dc/pnphy.c
  projects/bhyve/sys/dev/e1000/if_em.c
  projects/bhyve/sys/dev/e1000/if_igb.c
  projects/bhyve/sys/dev/e1000/if_igb.h
  projects/bhyve/sys/dev/en/if_en_pci.c
  projects/bhyve/sys/dev/et/if_et.c
  projects/bhyve/sys/dev/fdc/fdc_pccard.c
  projects/bhyve/sys/dev/firewire/fwohci.c
  projects/bhyve/sys/dev/fxp/if_fxp.c
  projects/bhyve/sys/dev/gem/if_gem.c
  projects/bhyve/sys/dev/gem/if_gemvar.h
  projects/bhyve/sys/dev/iicbus/if_ic.c
  projects/bhyve/sys/dev/mfi/mfi_cam.c
  projects/bhyve/sys/dev/mii/e1000phy.c
  projects/bhyve/sys/dev/mii/miidevs
  projects/bhyve/sys/dev/my/if_my.c
  projects/bhyve/sys/dev/pccbb/pccbb_pci.c
  projects/bhyve/sys/dev/pci/pci.c
  projects/bhyve/sys/dev/pci/pci_pci.c
  projects/bhyve/sys/dev/pty/pty.c
  projects/bhyve/sys/dev/sis/if_sis.c
  projects/bhyve/sys/dev/snp/snp.c
  projects/bhyve/sys/dev/sound/macio/i2s.c
  projects/bhyve/sys/dev/sound/usb/uaudio.c
  projects/bhyve/sys/dev/syscons/scterm-teken.c
  projects/bhyve/sys/dev/tdfx/tdfx_pci.c
  projects/bhyve/sys/dev/uart/uart_bus_pci.c
  projects/bhyve/sys/dev/usb/input/atp.c
  projects/bhyve/sys/dev/usb/input/uep.c
  projects/bhyve/sys/dev/usb/input/uhid.c
  projects/bhyve/sys/dev/usb/input/ukbd.c
  projects/bhyve/sys/dev/usb/input/ums.c
  projects/bhyve/sys/dev/usb/misc/udbp.c
  projects/bhyve/sys/dev/usb/misc/ufm.c
  projects/bhyve/sys/dev/usb/net/if_aue.c
  projects/bhyve/sys/dev/usb/net/if_axe.c
  projects/bhyve/sys/dev/usb/net/if_cdce.c
  projects/bhyve/sys/dev/usb/net/if_cue.c
  projects/bhyve/sys/dev/usb/net/if_ipheth.c
  projects/bhyve/sys/dev/usb/net/if_kue.c
  projects/bhyve/sys/dev/usb/net/if_mos.c
  projects/bhyve/sys/dev/usb/net/if_rue.c
  projects/bhyve/sys/dev/usb/net/if_udav.c
  projects/bhyve/sys/dev/usb/net/uhso.c
  projects/bhyve/sys/dev/usb/serial/u3g.c
  projects/bhyve/sys/dev/usb/serial/uark.c
  projects/bhyve/sys/dev/usb/serial/ubsa.c
  projects/bhyve/sys/dev/usb/serial/uchcom.c
  projects/bhyve/sys/dev/usb/serial/ucycom.c
  projects/bhyve/sys/dev/usb/serial/ufoma.c
  projects/bhyve/sys/dev/usb/serial/uftdi.c
  projects/bhyve/sys/dev/usb/serial/ugensa.c
  projects/bhyve/sys/dev/usb/serial/uipaq.c
  projects/bhyve/sys/dev/usb/serial/ulpt.c
  projects/bhyve/sys/dev/usb/serial/umcs.c
  projects/bhyve/sys/dev/usb/serial/umct.c
  projects/bhyve/sys/dev/usb/serial/umodem.c
  projects/bhyve/sys/dev/usb/serial/umoscom.c
  projects/bhyve/sys/dev/usb/serial/uplcom.c
  projects/bhyve/sys/dev/usb/serial/uslcom.c
  projects/bhyve/sys/dev/usb/serial/uvisor.c
  projects/bhyve/sys/dev/usb/serial/uvscom.c
  projects/bhyve/sys/dev/usb/storage/umass.c
  projects/bhyve/sys/dev/usb/storage/urio.c
  projects/bhyve/sys/dev/usb/template/usb_template.c
  projects/bhyve/sys/dev/usb/template/usb_template.h
  projects/bhyve/sys/dev/usb/template/usb_template_cdce.c
  projects/bhyve/sys/dev/usb/template/usb_template_msc.c
  projects/bhyve/sys/dev/usb/template/usb_template_mtp.c
  projects/bhyve/sys/dev/usb/usb_device.c
  projects/bhyve/sys/dev/usb/usb_hub.c
  projects/bhyve/sys/dev/usb/usb_ioctl.h
  projects/bhyve/sys/dev/usb/usb_lookup.c
  projects/bhyve/sys/dev/usb/usb_msctest.c
  projects/bhyve/sys/dev/usb/usbdi.h
  projects/bhyve/sys/dev/usb/wlan/if_rum.c
  projects/bhyve/sys/dev/usb/wlan/if_run.c
  projects/bhyve/sys/dev/usb/wlan/if_uath.c
  projects/bhyve/sys/dev/usb/wlan/if_upgt.c
  projects/bhyve/sys/dev/usb/wlan/if_ural.c
  projects/bhyve/sys/dev/usb/wlan/if_urtw.c
  projects/bhyve/sys/dev/usb/wlan/if_zyd.c
  projects/bhyve/sys/dev/vr/if_vr.c
  projects/bhyve/sys/dev/vr/if_vrreg.h
  projects/bhyve/sys/dev/xl/if_xl.c
  projects/bhyve/sys/fs/nfs/nfs_commonkrpc.c
  projects/bhyve/sys/fs/nfs/nfsproto.h
  projects/bhyve/sys/fs/nfsclient/nfs_clport.c
  projects/bhyve/sys/fs/nfsclient/nfs_clrpcops.c
  projects/bhyve/sys/fs/nfsserver/nfs_nfsdserv.c
  projects/bhyve/sys/fs/tmpfs/tmpfs_subr.c
  projects/bhyve/sys/geom/part/g_part_ebr.c
  projects/bhyve/sys/geom/part/g_part_gpt.c
  projects/bhyve/sys/geom/part/g_part_mbr.c
  projects/bhyve/sys/i386/i386/pmap.c
  projects/bhyve/sys/i386/i386/sys_machdep.c
  projects/bhyve/sys/i386/include/param.h
  projects/bhyve/sys/i386/include/pci_cfgreg.h
  projects/bhyve/sys/i386/xen/pmap.c
  projects/bhyve/sys/ia64/conf/NOTES
  projects/bhyve/sys/ia64/ia64/clock.c
  projects/bhyve/sys/ia64/ia64/db_machdep.c
  projects/bhyve/sys/ia64/ia64/interrupt.c
  projects/bhyve/sys/ia64/ia64/machdep.c
  projects/bhyve/sys/ia64/ia64/mp_machdep.c
  projects/bhyve/sys/ia64/ia64/pmap.c
  projects/bhyve/sys/ia64/include/pcpu.h
  projects/bhyve/sys/ia64/include/smp.h
  projects/bhyve/sys/kern/imgact_elf.c
  projects/bhyve/sys/kern/kern_clocksource.c
  projects/bhyve/sys/kern/kern_descrip.c
  projects/bhyve/sys/kern/kern_exec.c
  projects/bhyve/sys/kern/subr_kdb.c
  projects/bhyve/sys/kern/subr_smp.c
  projects/bhyve/sys/kern/subr_trap.c
  projects/bhyve/sys/kern/sys_capability.c
  projects/bhyve/sys/kern/tty.c
  projects/bhyve/sys/kern/tty_inq.c
  projects/bhyve/sys/kern/tty_outq.c
  projects/bhyve/sys/kern/tty_pts.c
  projects/bhyve/sys/kern/tty_ttydisc.c
  projects/bhyve/sys/kern/uipc_shm.c
  projects/bhyve/sys/kern/uipc_syscalls.c
  projects/bhyve/sys/kern/vfs_subr.c
  projects/bhyve/sys/mips/atheros/ar71xx_chip.c
  projects/bhyve/sys/mips/atheros/ar71xx_machdep.c
  projects/bhyve/sys/mips/atheros/ar71xx_ohci.c
  projects/bhyve/sys/mips/atheros/ar71xx_setup.c
  projects/bhyve/sys/mips/atheros/ar724x_chip.c
  projects/bhyve/sys/mips/atheros/ar91xx_chip.c
  projects/bhyve/sys/mips/mips/genassym.c
  projects/bhyve/sys/mips/mips/pmap.c
  projects/bhyve/sys/mips/mips/trap.c
  projects/bhyve/sys/mips/rmi/dev/xlr/rge.c
  projects/bhyve/sys/mips/rmi/fmn.c
  projects/bhyve/sys/mips/rmi/iodi.c
  projects/bhyve/sys/mips/sentry5/s5_machdep.c
  projects/bhyve/sys/mips/sibyte/sb_machdep.c
  projects/bhyve/sys/modules/Makefile
  projects/bhyve/sys/modules/cxgbe/if_cxgbe/Makefile
  projects/bhyve/sys/modules/ipdivert/Makefile
  projects/bhyve/sys/modules/nfscl/Makefile
  projects/bhyve/sys/modules/nfscommon/Makefile
  projects/bhyve/sys/modules/pf/Makefile
  projects/bhyve/sys/modules/pflog/Makefile
  projects/bhyve/sys/modules/usb/template/Makefile
  projects/bhyve/sys/net/if.c
  projects/bhyve/sys/net/route.c
  projects/bhyve/sys/net/route.h
  projects/bhyve/sys/net80211/ieee80211_dfs.c
  projects/bhyve/sys/netgraph/bluetooth/drivers/ubt/ng_ubt.c
  projects/bhyve/sys/netgraph/bluetooth/drivers/ubtbcmfw/ubtbcmfw.c
  projects/bhyve/sys/netgraph/ng_ether.c
  projects/bhyve/sys/netinet/in_gif.c
  projects/bhyve/sys/netinet/ip_divert.c
  projects/bhyve/sys/netinet/ip_fw.h
  projects/bhyve/sys/netinet/ip_icmp.c
  projects/bhyve/sys/netinet/ip_var.h
  projects/bhyve/sys/netinet/ipfw/ip_dn_io.c
  projects/bhyve/sys/netinet/ipfw/ip_fw2.c
  projects/bhyve/sys/netinet/ipfw/ip_fw_log.c
  projects/bhyve/sys/netinet/ipfw/ip_fw_pfil.c
  projects/bhyve/sys/netinet/ipfw/ip_fw_sockopt.c
  projects/bhyve/sys/netinet/libalias/alias_db.c
  projects/bhyve/sys/netinet/libalias/alias_ftp.c
  projects/bhyve/sys/netinet/libalias/alias_local.h
  projects/bhyve/sys/netinet/libalias/libalias.3
  projects/bhyve/sys/netinet/raw_ip.c
  projects/bhyve/sys/netinet/sctp_uio.h
  projects/bhyve/sys/netinet6/icmp6.c
  projects/bhyve/sys/netinet6/in6_gif.c
  projects/bhyve/sys/netipsec/ipsec_input.c
  projects/bhyve/sys/netipsec/ipsec_output.c
  projects/bhyve/sys/netipsec/xform_ipip.c
  projects/bhyve/sys/nfs/bootp_subr.c
  projects/bhyve/sys/powerpc/aim/copyinout.c
  projects/bhyve/sys/powerpc/aim/locore32.S
  projects/bhyve/sys/powerpc/aim/locore64.S
  projects/bhyve/sys/powerpc/aim/machdep.c
  projects/bhyve/sys/powerpc/aim/mmu_oea64.c
  projects/bhyve/sys/powerpc/aim/mp_cpudep.c
  projects/bhyve/sys/powerpc/aim/swtch32.S
  projects/bhyve/sys/powerpc/aim/swtch64.S
  projects/bhyve/sys/powerpc/aim/trap.c
  projects/bhyve/sys/powerpc/aim/trap_subr32.S
  projects/bhyve/sys/powerpc/aim/trap_subr64.S
  projects/bhyve/sys/powerpc/booke/copyinout.c
  projects/bhyve/sys/powerpc/booke/interrupt.c
  projects/bhyve/sys/powerpc/booke/trap.c
  projects/bhyve/sys/powerpc/include/pcpu.h
  projects/bhyve/sys/powerpc/ofw/ofwcall32.S
  projects/bhyve/sys/powerpc/ofw/rtas.c
  projects/bhyve/sys/powerpc/powermac/fcu.c
  projects/bhyve/sys/powerpc/powerpc/db_trace.c
  projects/bhyve/sys/powerpc/powerpc/mp_machdep.c
  projects/bhyve/sys/powerpc/ps3/ps3-hvcall.h
  projects/bhyve/sys/powerpc/ps3/ps3-hvcall.master
  projects/bhyve/sys/powerpc/ps3/ps3bus.c
  projects/bhyve/sys/powerpc/ps3/ps3disk.c
  projects/bhyve/sys/powerpc/ps3/ps3pic.c
  projects/bhyve/sys/sparc64/include/tsb.h
  projects/bhyve/sys/sparc64/include/vmparam.h
  projects/bhyve/sys/sparc64/sparc64/pmap.c
  projects/bhyve/sys/sparc64/sparc64/sys_machdep.c
  projects/bhyve/sys/sys/diskmbr.h
  projects/bhyve/sys/sys/filedesc.h
  projects/bhyve/sys/sys/mbuf.h
  projects/bhyve/sys/sys/param.h
  projects/bhyve/sys/sys/soundcard.h
  projects/bhyve/sys/sys/systm.h
  projects/bhyve/sys/teken/demo/teken_demo.c
  projects/bhyve/sys/teken/gensequences
  projects/bhyve/sys/teken/libteken/teken.3
  projects/bhyve/sys/teken/teken.c
  projects/bhyve/sys/teken/teken_subr.h
  projects/bhyve/sys/ufs/ffs/ffs_inode.c
  projects/bhyve/sys/ufs/ffs/ffs_softdep.c
  projects/bhyve/sys/vm/vm_fault.c
  projects/bhyve/sys/vm/vm_map.c
  projects/bhyve/sys/vm/vm_object.c
  projects/bhyve/sys/vm/vm_object.h
  projects/bhyve/sys/vm/vm_page.c
  projects/bhyve/sys/vm/vnode_pager.c
  projects/bhyve/sys/x86/x86/tsc.c
  projects/bhyve/usr.bin/calendar/calendars/calendar.freebsd
  projects/bhyve/usr.bin/calendar/calendars/ru_RU.KOI8-R/calendar.all
  projects/bhyve/usr.bin/cmp/regular.c
  projects/bhyve/usr.bin/cmp/special.c
  projects/bhyve/usr.bin/finger/net.c
  projects/bhyve/usr.bin/ktrace/ktrace.c
  projects/bhyve/usr.bin/lastcomm/lastcomm.c
  projects/bhyve/usr.bin/lastcomm/readrec.c
  projects/bhyve/usr.bin/ncplogin/ncplogin.c
  projects/bhyve/usr.bin/quota/quota.c
  projects/bhyve/usr.bin/systat/netstat.c
  projects/bhyve/usr.bin/tar/util.c
  projects/bhyve/usr.bin/tar/write.c
  projects/bhyve/usr.bin/tftp/main.c
  projects/bhyve/usr.bin/tftp/tftp.1
  projects/bhyve/usr.bin/vmstat/vmstat.c
  projects/bhyve/usr.sbin/ancontrol/ancontrol.c
  projects/bhyve/usr.sbin/ftp-proxy/ftp-proxy/Makefile
  projects/bhyve/usr.sbin/ifmcstat/ifmcstat.c
  projects/bhyve/usr.sbin/mtest/mtest.c
  projects/bhyve/usr.sbin/nfsd/nfsd.c
  projects/bhyve/usr.sbin/nfsuserd/nfsuserd.c
  projects/bhyve/usr.sbin/pmcstat/pmcpl_calltree.c
  projects/bhyve/usr.sbin/ppp/nat_cmd.c
  projects/bhyve/usr.sbin/rpc.yppasswdd/yppasswdd_main.c
  projects/bhyve/usr.sbin/rpc.ypupdated/update.c
  projects/bhyve/usr.sbin/rpc.ypupdated/ypupdated_main.c
  projects/bhyve/usr.sbin/rpc.ypupdated/ypupdated_server.c
  projects/bhyve/usr.sbin/sysinstall/modules.c
  projects/bhyve/usr.sbin/wpa/ndis_events/ndis_events.c
  projects/bhyve/usr.sbin/wpa/wpa_supplicant/Packet32.c
Directory Properties:
  projects/bhyve/   (props changed)
  projects/bhyve/cddl/contrib/opensolaris/   (props changed)
  projects/bhyve/contrib/bind9/   (props changed)
  projects/bhyve/contrib/binutils/   (props changed)
  projects/bhyve/contrib/bzip2/   (props changed)
  projects/bhyve/contrib/compiler-rt/   (props changed)
  projects/bhyve/contrib/dialog/   (props changed)
  projects/bhyve/contrib/ee/   (props changed)
  projects/bhyve/contrib/expat/   (props changed)
  projects/bhyve/contrib/file/   (props changed)
  projects/bhyve/contrib/gcc/   (props changed)
  projects/bhyve/contrib/gdb/   (props changed)
  projects/bhyve/contrib/gdtoa/   (props changed)
  projects/bhyve/contrib/gnu-sort/   (props changed)
  projects/bhyve/contrib/groff/   (props changed)
  projects/bhyve/contrib/less/   (props changed)
  projects/bhyve/contrib/libpcap/   (props changed)
  projects/bhyve/contrib/libstdc++/   (props changed)
  projects/bhyve/contrib/llvm/   (props changed)
  projects/bhyve/contrib/llvm/tools/clang/   (props changed)
  projects/bhyve/contrib/ncurses/   (props changed)
  projects/bhyve/contrib/netcat/   (props changed)
  projects/bhyve/contrib/ntp/   (props changed)
  projects/bhyve/contrib/one-true-awk/   (props changed)
  projects/bhyve/contrib/openbsm/   (props changed)
  projects/bhyve/contrib/openpam/   (props changed)
  projects/bhyve/contrib/pf/   (props changed)
  projects/bhyve/contrib/sendmail/   (props changed)
  projects/bhyve/contrib/tcpdump/   (props changed)
  projects/bhyve/contrib/tcsh/   (props changed)
  projects/bhyve/contrib/tnftp/   (props changed)
  projects/bhyve/contrib/top/   (props changed)
  projects/bhyve/contrib/top/install-sh   (props changed)
  projects/bhyve/contrib/tzcode/stdtime/   (props changed)
  projects/bhyve/contrib/tzcode/zic/   (props changed)
  projects/bhyve/contrib/tzdata/   (props changed)
  projects/bhyve/contrib/wpa/   (props changed)
  projects/bhyve/contrib/xz/   (props changed)
  projects/bhyve/crypto/openssh/   (props changed)
  projects/bhyve/crypto/openssl/   (props changed)
  projects/bhyve/gnu/lib/   (props changed)
  projects/bhyve/gnu/usr.bin/binutils/   (props changed)
  projects/bhyve/gnu/usr.bin/cc/cc_tools/   (props changed)
  projects/bhyve/gnu/usr.bin/gdb/   (props changed)
  projects/bhyve/lib/libc/   (props changed)
  projects/bhyve/lib/libc/stdtime/   (props changed)
  projects/bhyve/lib/libutil/   (props changed)
  projects/bhyve/lib/libz/   (props changed)
  projects/bhyve/sbin/   (props changed)
  projects/bhyve/sbin/ipfw/   (props changed)
  projects/bhyve/share/mk/bsd.arch.inc.mk   (props changed)
  projects/bhyve/share/zoneinfo/   (props changed)
  projects/bhyve/sys/   (props changed)
  projects/bhyve/sys/amd64/include/xen/   (props changed)
  projects/bhyve/sys/boot/   (props changed)
  projects/bhyve/sys/boot/i386/efi/   (props changed)
  projects/bhyve/sys/boot/ia64/efi/   (props changed)
  projects/bhyve/sys/boot/ia64/ski/   (props changed)
  projects/bhyve/sys/boot/powerpc/boot1.chrp/   (props changed)
  projects/bhyve/sys/boot/powerpc/ofw/   (props changed)
  projects/bhyve/sys/cddl/contrib/opensolaris/   (props changed)
  projects/bhyve/sys/conf/   (props changed)
  projects/bhyve/sys/contrib/dev/acpica/   (props changed)
  projects/bhyve/sys/contrib/octeon-sdk/   (props changed)
  projects/bhyve/sys/contrib/pf/   (props changed)
  projects/bhyve/sys/contrib/x86emu/   (props changed)
  projects/bhyve/usr.bin/calendar/   (props changed)
  projects/bhyve/usr.bin/csup/   (props changed)
  projects/bhyve/usr.bin/procstat/   (props changed)
  projects/bhyve/usr.sbin/ndiscvt/   (props changed)
  projects/bhyve/usr.sbin/zic/   (props changed)

Modified: projects/bhyve/UPDATING
==============================================================================
--- projects/bhyve/UPDATING	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/UPDATING	Thu Jun 30 17:37:42 2011	(r223698)
@@ -22,6 +22,12 @@ NOTE TO PEOPLE WHO THINK THAT FreeBSD 9.
 	machines to maximize performance.  (To disable malloc debugging, run
 	ln -s aj /etc/malloc.conf.)
 
+20110628:
+	The packet filter (pf) code has been updated to OpenBSD 4.5.
+	You need to update userland tools to be in sync with kernel.
+	This update breaks backward compatibility with earlier pfsync(4)
+	versions.  Care must be taken when updating redundant firewall setups.
+
 20110608:
 	The following sysctls and tunables are retired on x86 platforms:
 		machdep.hlt_cpus

Modified: projects/bhyve/bin/rcp/rcp.c
==============================================================================
--- projects/bhyve/bin/rcp/rcp.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/bin/rcp/rcp.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -71,7 +71,6 @@ __FBSDID("$FreeBSD$");
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
-#include <string.h>
 #include <unistd.h>
 
 #include "extern.h"

Modified: projects/bhyve/bin/realpath/realpath.1
==============================================================================
--- projects/bhyve/bin/realpath/realpath.1	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/bin/realpath/realpath.1	Thu Jun 30 17:37:42 2011	(r223698)
@@ -33,7 +33,7 @@
 .\" From: src/bin/pwd/pwd.1,v 1.11 2000/11/20 11:39:39 ru Exp
 .\" $FreeBSD$
 .\"
-.Dd November 24, 2000
+.Dd June 21, 2011
 .Dt REALPATH 1
 .Os
 .Sh NAME
@@ -42,8 +42,7 @@
 .Sh SYNOPSIS
 .Nm
 .Op Fl q
-.Ar path
-.Op Ar ...
+.Op Ar path ...
 .Sh DESCRIPTION
 The
 .Nm
@@ -57,6 +56,11 @@ and
 .Pa /../
 in
 .Ar path .
+If
+.Ar path
+is absent, the current working directory
+.Pq Sq Pa .\&
+is assumed.
 .Pp
 If
 .Fl q

Modified: projects/bhyve/bin/realpath/realpath.c
==============================================================================
--- projects/bhyve/bin/realpath/realpath.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/bin/realpath/realpath.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -44,7 +44,8 @@ main(int argc, char *argv[])
 {
 	char buf[PATH_MAX];
 	char *p;
-	int ch, i, qflag, rval;
+	const char *path;
+	int ch, qflag, rval;
 
 	qflag = 0;
 	while ((ch = getopt(argc, argv, "q")) != -1) {
@@ -59,17 +60,16 @@ main(int argc, char *argv[])
 	}
 	argc -= optind;
 	argv += optind;
-	if (argc < 1)
-		usage();
+	path = *argv != NULL ? *argv++ : ".";
 	rval  = 0;
-	for (i = 0; i < argc; i++) {
-		if ((p = realpath(argv[i], buf)) == NULL) {
+	do {
+		if ((p = realpath(path, buf)) == NULL) {
 			if (!qflag)
-				warn("%s", argv[i]);
+				warn("%s", path);
 			rval = 1;
 		} else
 			(void)printf("%s\n", p);
-	}
+	} while ((path = *argv++) != NULL);
 	exit(rval);
 }
 
@@ -77,6 +77,6 @@ static void
 usage(void)
 {
 
-	(void)fprintf(stderr, "usage: realpath [-q] path [...]\n");
+	(void)fprintf(stderr, "usage: realpath [-q] [path ...]\n");
   	exit(1);
 }

Modified: projects/bhyve/bin/sh/arith_yacc.c
==============================================================================
--- projects/bhyve/bin/sh/arith_yacc.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/bin/sh/arith_yacc.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -35,7 +35,7 @@
 #include <sys/cdefs.h>
 __FBSDID("$FreeBSD$");
 
-#include <sys/limits.h>
+#include <limits.h>
 #include <errno.h>
 #include <inttypes.h>
 #include <stdlib.h>

Modified: projects/bhyve/bin/sh/mkinit.c
==============================================================================
--- projects/bhyve/bin/sh/mkinit.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/bin/sh/mkinit.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -55,7 +55,6 @@ __FBSDID("$FreeBSD$");
  */
 
 
-#include <sys/cdefs.h>
 #include <sys/types.h>
 #include <stdio.h>
 #include <stdlib.h>

Modified: projects/bhyve/bin/sh/sh.1
==============================================================================
--- projects/bhyve/bin/sh/sh.1	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/bin/sh/sh.1	Thu Jun 30 17:37:42 2011	(r223698)
@@ -32,7 +32,7 @@
 .\"	from: @(#)sh.1	8.6 (Berkeley) 5/4/95
 .\" $FreeBSD$
 .\"
-.Dd June 18, 2011
+.Dd June 24, 2011
 .Dt SH 1
 .Os
 .Sh NAME
@@ -994,11 +994,22 @@ described later),
 separated by
 .Ql \&|
 characters.
+Tilde expansion, parameter expansion, command substitution,
+arithmetic expansion and quote removal are applied to the word.
+Then, each pattern is expanded in turn using tilde expansion,
+parameter expansion, command substitution and arithmetic expansion and
+the expanded form of the word is checked against it.
+If a match is found, the corresponding list is executed.
 If the selected list is terminated by the control operator
 .Ql ;&
 instead of
 .Ql ;; ,
-execution continues with the next list.
+execution continues with the next list,
+continuing until a list terminated with
+.Ql ;;
+or the end of the
+.Ic case
+command.
 The exit code of the
 .Ic case
 command is the exit code of the last command executed in the list or
@@ -1618,15 +1629,15 @@ There are two restrictions on this: firs
 a string containing a slash, and second,
 a pattern cannot match a string starting with a period
 unless the first character of the pattern is a period.
-The next section describes the patterns used for both
-Pathname Expansion and the
+The next section describes the patterns used for
+Pathname Expansion,
+the four varieties of parameter expansion for substring processing and the
 .Ic case
 command.
 .Ss Shell Patterns
 A pattern consists of normal characters, which match themselves,
 and meta-characters.
 The meta-characters are
-.Ql \&! ,
 .Ql * ,
 .Ql \&? ,
 and
@@ -1656,7 +1667,7 @@ matches a
 .Ql \&[
 rather than introducing a character class.
 A character class matches any of the characters between the square brackets.
-A range of characters may be specified using a minus sign.
+A locale-dependent range of characters may be specified using a minus sign.
 A named class of characters (see
 .Xr wctype 3 )
 may be specified by surrounding the name with
@@ -1669,12 +1680,17 @@ is a shell pattern that matches a single
 The character class may be complemented by making an exclamation point
 .Pq Ql !\&
 the first character of the character class.
+A caret
+.Pq Ql ^
+has the same effect but is non-standard.
 .Pp
 To include a
 .Ql \&]
 in a character class, make it the first character listed
 (after the
-.Ql \&! ,
+.Ql \&!
+or
+.Ql ^ ,
 if any).
 To include a
 .Ql - ,

Modified: projects/bhyve/cddl/contrib/opensolaris/cmd/zfs/zfs.8
==============================================================================
--- projects/bhyve/cddl/contrib/opensolaris/cmd/zfs/zfs.8	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/cddl/contrib/opensolaris/cmd/zfs/zfs.8	Thu Jun 30 17:37:42 2011	(r223698)
@@ -6,6 +6,7 @@
 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License").  You may not use this file except in compliance with the License. You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing.
 .\"  See the License for the specific language governing permissions and limitations under the License. When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE.  If applicable, add the following below this CDDL HEADER, with
 .\" the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
+.\" Copyright 2011 by Delphix.  All rights reserved.
 .TH zfs 1M "24 Sep 2009" "SunOS 5.11" "System Administration Commands"
 .SH NAME
 zfs \- configures ZFS file systems
@@ -389,7 +390,7 @@ This property can also be referred to by
 .ad
 .sp .6
 .RS 4n
-The compression ratio achieved for this dataset, expressed as a multiplier. Compression can be turned on by running: \fBzfs set compression=on \fIdataset\fR\fR. The default value is \fBoff\fR.
+For non-snapshots, the compression ratio achieved for the \fBused\fR space of this dataset, expressed as a multiplier.  The \fBused\fR property includes descendant datasets, and, for clones, does not include the space shared with the origin snapshot.  For snapshots, the \fBcompressratio\fR is the same as the \fBrefcompressratio\fR property. Compression can be turned on by running: \fBzfs set compression=on \fIdataset\fR\fR. The default value is \fBoff\fR.
 .RE
 
 .sp
@@ -453,6 +454,17 @@ This property can also be referred to by
 .ne 2
 .mk
 .na
+\fB\fBrefcompressratio\fR\fR
+.ad
+.sp .6
+.RS 4n
+The compression ratio achieved for the \fBreferenced\fR space of this dataset, expressed as a multiplier.  See also the \fBcompressratio\fR property.
+.RE
+
+.sp
+.ne 2
+.mk
+.na
 \fB\fBtype\fR\fR
 .ad
 .sp .6
@@ -1278,7 +1290,7 @@ Recursively destroy all dependents, incl
 Force an unmount of any file systems using the \fBunmount -f\fR command. This option has no effect on non-file systems or unmounted file systems.
 .RE
 
-Extreme care should be taken when applying either the \fB-r\fR or the \fB-f\fR options, as they can destroy large portions of a pool and cause unexpected behavior for mounted file systems in use. 
+Extreme care should be taken when applying either the \fB-r\fR or the \fB-R\fR options, as they can destroy large portions of a pool and cause unexpected behavior for mounted file systems in use. 
 .RE
 
 .sp

Modified: projects/bhyve/cddl/contrib/opensolaris/cmd/zfs/zfs_main.c
==============================================================================
--- projects/bhyve/cddl/contrib/opensolaris/cmd/zfs/zfs_main.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/cddl/contrib/opensolaris/cmd/zfs/zfs_main.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -21,7 +21,7 @@
 
 /*
  * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
- * Copyright 2010 Nexenta Systems, Inc. All rights reserved.
+ * Copyright 2011 Nexenta Systems, Inc. All rights reserved.
  */
 
 #include <assert.h>
@@ -1292,7 +1292,7 @@ static int
 zfs_do_get(int argc, char **argv)
 {
 	zprop_get_cbdata_t cb = { 0 };
-	int i, c, flags = 0;
+	int i, c, flags = ZFS_ITER_ARGS_CAN_BE_PATHS;
 	char *value, *fields;
 	int ret;
 	int limit = 0;

Modified: projects/bhyve/cddl/contrib/opensolaris/lib/libzfs/common/libzfs_dataset.c
==============================================================================
--- projects/bhyve/cddl/contrib/opensolaris/lib/libzfs/common/libzfs_dataset.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/cddl/contrib/opensolaris/lib/libzfs/common/libzfs_dataset.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -22,6 +22,7 @@
 /*
  * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
  * Copyright 2010 Nexenta Systems, Inc. All rights reserved.
+ * Copyright (c) 2011 by Delphix. All rights reserved.
  */
 
 #include <ctype.h>
@@ -2038,6 +2039,7 @@ zfs_prop_get(zfs_handle_t *zhp, zfs_prop
 		}
 		break;
 
+	case ZFS_PROP_REFRATIO:
 	case ZFS_PROP_COMPRESSRATIO:
 		if (get_numeric_property(zhp, prop, src, &source, &val) != 0)
 			return (-1);

Modified: projects/bhyve/contrib/binutils/gas/config/tc-arm.c
==============================================================================
--- projects/bhyve/contrib/binutils/gas/config/tc-arm.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/contrib/binutils/gas/config/tc-arm.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -9974,6 +9974,13 @@ do_t_rbit (void)
 }
 
 static void
+do_t_rd_rm (void)
+{
+  inst.instruction |= inst.operands[0].reg << 8;
+  inst.instruction |= inst.operands[1].reg;
+}
+
+static void
 do_t_rev (void)
 {
   if (inst.operands[0].reg <= 7 && inst.operands[1].reg <= 7
@@ -14901,6 +14908,9 @@ static const struct asm_opcode insns[] =
  TCE(rsb,	0600000, ebc00000, 3, (RR, oRR, SH), arit, t_rsb),
  TC3(rsbs,	0700000, ebd00000, 3, (RR, oRR, SH), arit, t_rsb),
 
+ TCE(rrx,      1a00060, ea4f0030, 2, (RR, RR),      rd_rm, t_rd_rm),
+ TCE(rrxs,     1b00060, ea5f0030, 2, (RR, RR),      rd_rm, t_rd_rm),
+
 #undef THUMB_VARIANT
 #define THUMB_VARIANT &arm_ext_v6
  TCE(cpy,       1a00000, 4600,     2, (RR, RR),      rd_rm, t_cpy),

Modified: projects/bhyve/contrib/libpcap/bpf/net/bpf_filter.c
==============================================================================
--- projects/bhyve/contrib/libpcap/bpf/net/bpf_filter.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/contrib/libpcap/bpf/net/bpf_filter.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -405,7 +405,18 @@ bpf_filter(pc, p, wirelen, buflen)
 			continue;
 
 		case BPF_JMP|BPF_JA:
+#if defined(KERNEL) || defined(_KERNEL)
+			/*
+			 * No backward jumps allowed.
+			 */
 			pc += pc->k;
+#else
+			/*
+			 * XXX - we currently implement "ip6 protochain"
+			 * with backward jumps, so sign-extend pc->k.
+			 */
+			pc += (bpf_int32)pc->k;
+#endif
 			continue;
 
 		case BPF_JMP|BPF_JGT|BPF_K:

Modified: projects/bhyve/contrib/ntp/ntpd/ntp_config.c
==============================================================================
--- projects/bhyve/contrib/ntp/ntpd/ntp_config.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/contrib/ntp/ntpd/ntp_config.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -414,7 +414,7 @@ enum gnn_type {
 static	int getnetnum P((const char *, struct sockaddr_storage *, int,
 			 enum gnn_type));
 static	void save_resolve P((char *, int, int, int, int, u_int, int,
-    keyid_t, u_char *));
+    keyid_t, u_char *, u_char));
 static	void do_resolve_internal P((void));
 static	void abort_resolve P((void));
 #if !defined(VMS) && !defined(SYS_WINNT)
@@ -870,9 +870,9 @@ getconfig(
 						stoa(&peeraddr));
 			    }
 			} else if (errflg == -1) {
-				save_resolve(tokens[1], hmode, peerversion,
+				save_resolve(tokens[istart - 1], hmode, peerversion,
 				    minpoll, maxpoll, peerflags, ttl,
-				    peerkey, peerkeystr);
+				    peerkey, peerkeystr, peeraddr.ss_family);
 			}
 			break;
 
@@ -2325,7 +2325,8 @@ save_resolve(
 	u_int flags,
 	int ttl,
 	keyid_t keyid,
-	u_char *keystr
+	u_char *keystr,
+	u_char peeraf
 	)
 {
 #ifndef SYS_VXWORKS
@@ -2365,11 +2366,11 @@ save_resolve(
 	}
 #endif
 
-	(void)fprintf(res_fp, "%s %d %d %d %d %d %d %u %s\n", name,
+	(void)fprintf(res_fp, "%s %u %d %d %d %d %d %d %u %s\n", name, peeraf,
 	    mode, version, minpoll, maxpoll, flags, ttl, keyid, keystr);
 #ifdef DEBUG
 	if (debug > 1)
-		printf("config: %s %d %d %d %d %x %d %u %s\n", name, mode,
+		printf("config: %s %u %d %d %d %d %x %d %u %s\n", name, peeraf, mode,
 		    version, minpoll, maxpoll, flags, ttl, keyid, keystr);
 #endif
 

Modified: projects/bhyve/contrib/ntp/ntpd/ntp_intres.c
==============================================================================
--- projects/bhyve/contrib/ntp/ntpd/ntp_intres.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/contrib/ntp/ntpd/ntp_intres.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -29,6 +29,7 @@
 
 #include <stdio.h>
 #include <ctype.h>
+#include <resolv.h>
 #include <signal.h>
 
 /**/
@@ -111,15 +112,16 @@ static	int resolve_value;	/* next value 
  * is supposed to consist of entries in the following order
  */
 #define	TOK_HOSTNAME	0
-#define	TOK_HMODE	1
-#define	TOK_VERSION	2
-#define TOK_MINPOLL	3
-#define TOK_MAXPOLL	4
-#define	TOK_FLAGS	5
-#define TOK_TTL		6
-#define	TOK_KEYID	7
-#define TOK_KEYSTR	8
-#define	NUMTOK		9
+#define	TOK_PEERAF	1
+#define	TOK_HMODE	2
+#define	TOK_VERSION	3
+#define TOK_MINPOLL	4
+#define TOK_MAXPOLL	5
+#define	TOK_FLAGS	6
+#define TOK_TTL		7
+#define	TOK_KEYID	8
+#define TOK_KEYSTR	9
+#define	NUMTOK		10
 
 #define	MAXLINESIZE	512
 
@@ -140,7 +142,7 @@ char *req_file;		/* name of the file wit
 static	void	checkparent	P((void));
 static	void	removeentry	P((struct conf_entry *));
 static	void	addentry	P((char *, int, int, int, int, u_int,
-				   int, keyid_t, char *));
+				   int, keyid_t, char *, u_char));
 static	int	findhostaddr	P((struct conf_entry *));
 static	void	openntp		P((void));
 static	int	request		P((struct conf_peer *));
@@ -397,7 +399,8 @@ addentry(
 	u_int flags,
 	int ttl,
 	keyid_t keyid,
-	char *keystr
+	char *keystr,
+	u_char peeraf
 	)
 {
 	register char *cp;
@@ -407,7 +410,7 @@ addentry(
 #ifdef DEBUG
 	if (debug > 1)
 		msyslog(LOG_INFO, 
-		    "intres: <%s> %d %d %d %d %x %d %x %s\n", name,
+		    "intres: <%s> %u %d %d %d %d %x %d %x %s\n", name, peeraf,
 		    mode, version, minpoll, maxpoll, flags, ttl, keyid,
 		    keystr);
 #endif
@@ -422,6 +425,7 @@ addentry(
 	ce->ce_peeraddr6 = in6addr_any;
 #endif
 	ANYSOCK(&ce->peer_store);
+	ce->peer_store.ss_family = peeraf;	/* Save AF for getaddrinfo hints. */
 	ce->ce_hmode = (u_char)mode;
 	ce->ce_version = (u_char)version;
 	ce->ce_minpoll = (u_char)minpoll;
@@ -482,7 +486,8 @@ findhostaddr(
 			entry->ce_name));
 
 		memset(&hints, 0, sizeof(hints));
-		hints.ai_family = AF_UNSPEC;
+		hints.ai_family = entry->peer_store.ss_family;
+		hints.ai_socktype = SOCK_DGRAM;
 		/*
 		 * If the IPv6 stack is not available look only for IPv4 addresses
 		 */
@@ -1051,6 +1056,13 @@ readconf(
 			}
 		}
 
+		if (intval[TOK_PEERAF] != AF_UNSPEC && intval[TOK_PEERAF] !=
+		    AF_INET && intval[TOK_PEERAF] != AF_INET6) {
+			msyslog(LOG_ERR, "invalid peer address family (%u) in "
+			    "file %s", intval[TOK_PEERAF], name);
+			exit(1);
+		}
+
 		if (intval[TOK_HMODE] != MODE_ACTIVE &&
 		    intval[TOK_HMODE] != MODE_CLIENT &&
 		    intval[TOK_HMODE] != MODE_BROADCAST) {
@@ -1107,7 +1119,7 @@ readconf(
 		addentry(token[TOK_HOSTNAME], (int)intval[TOK_HMODE],
 			 (int)intval[TOK_VERSION], (int)intval[TOK_MINPOLL],
 			 (int)intval[TOK_MAXPOLL], flags, (int)intval[TOK_TTL],
-			 intval[TOK_KEYID], token[TOK_KEYSTR]);
+			 intval[TOK_KEYID], token[TOK_KEYSTR], (u_char)intval[TOK_PEERAF]);
 	}
 }
 
@@ -1129,6 +1141,9 @@ doconfigure(
 			    dores ? "with" : "without" );
 #endif
 
+	if (dores)         /* Reload /etc/resolv.conf - bug 1226 */
+		res_init();
+
 	ce = confentries;
 	while (ce != NULL) {
 #ifdef DEBUG

Modified: projects/bhyve/contrib/ntp/ntpd/ntp_io.c
==============================================================================
--- projects/bhyve/contrib/ntp/ntpd/ntp_io.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/contrib/ntp/ntpd/ntp_io.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -2716,14 +2716,14 @@ sendpkt(
 
 	for (slot = ERRORCACHESIZE; --slot >= 0; )
 		if(dest->ss_family == AF_INET) {
-			if (badaddrs[slot].port == ((struct sockaddr_in*)dest)->sin_port &&
+			if (badaddrs[slot].port == SRCPORT(dest) &&
 				badaddrs[slot].addr.s_addr == ((struct sockaddr_in*)dest)->sin_addr.s_addr)
 			break;
 		}
 #ifdef INCLUDE_IPV6_SUPPORT
 		else if (dest->ss_family == AF_INET6) {
-			if (badaddrs6[slot].port == ((struct sockaddr_in6*)dest)->sin6_port &&
-				badaddrs6[slot].addr.s6_addr == ((struct sockaddr_in6*)dest)->sin6_addr.s6_addr)
+			if (badaddrs6[slot].port == SRCPORT(dest) &&
+				!memcmp(&badaddrs6[slot].addr, &((struct sockaddr_in6*)dest)->sin6_addr, sizeof(struct in6_addr)))
 			break;
 		}
 #endif /* INCLUDE_IPV6_SUPPORT */

Modified: projects/bhyve/contrib/pf/authpf/authpf.8
==============================================================================
--- projects/bhyve/contrib/pf/authpf/authpf.8	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/contrib/pf/authpf/authpf.8	Thu Jun 30 17:37:42 2011	(r223698)
@@ -1,5 +1,5 @@
 .\" $FreeBSD$
-.\" $OpenBSD: authpf.8,v 1.43 2007/02/24 17:21:04 beck Exp $
+.\" $OpenBSD: authpf.8,v 1.47 2009/01/06 03:11:50 mcbride Exp $
 .\"
 .\" Copyright (c) 1998-2007 Bob Beck (beck at openbsd.org>.  All rights reserved.
 .\"
@@ -15,14 +15,16 @@
 .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 .\"
-.Dd March 28, 2006
+.Dd January 6 2009
 .Dt AUTHPF 8
 .Os
 .Sh NAME
-.Nm authpf
+.Nm authpf ,
+.Nm authpf-noip
 .Nd authenticating gateway user shell
 .Sh SYNOPSIS
 .Nm authpf
+.Nm authpf-noip
 .Sh DESCRIPTION
 .Nm
 is a user shell for authenticating gateways.
@@ -31,47 +33,63 @@ It is used to change
 rules when a user authenticates and starts a session with
 .Xr sshd 8
 and to undo these changes when the user's session exits.
-It is designed for changing filter and translation rules for an individual
-source IP address as long as a user maintains an active
-.Xr ssh 1
-session.
 Typical use would be for a gateway that authenticates users before
 allowing them Internet use, or a gateway that allows different users into
 different places.
+Combined with properly set up filter rules and secure switches,
 .Nm
-logs the successful start and end of a session to
-.Xr syslogd 8 .
-This, combined with properly set up filter rules and secure switches,
 can be used to ensure users are held accountable for their network traffic.
-.Pp
-.Nm
-can add filter and translation rules using the syntax described in
-.Xr pf.conf 5 .
-.Nm
-requires that the
+It is meant to be used with users who can connect via
+.Xr ssh 1
+only, and requires the
 .Xr pf 4
-system be enabled and a 
-.Xr fdescfs 5
-file system be mounted at
-.Pa /dev/fd
-before use.
+subsystem to be enabled.
+.Pp
+.Nm authpf-noip
+is a user shell
+which allows multiple connections to take
+place from the same IP address.
+It is useful primarily in cases where connections are tunneled via
+the gateway system, and can be directly associated with the user name.
+It cannot ensure accountability when
+classifying connections by IP address;
+in this case the client's IP address
+is not provided to the packet filter via the
+.Ar client_ip
+macro or the
+.Ar authpf_users
+table.
+Additionally, states associated with the client IP address
+are not purged when the session is ended.
+.Pp
+To use either
 .Nm
-can also maintain the list of IP address of connected users
-in the "authpf_users"
-.Pa table .
+or
+.Nm authpf-noip ,
+the user's shell needs to be set to
+.Pa /usr/sbin/authpf
+or
+.Pa /usr/sbin/authpf-noip .
 .Pp
 .Nm
-is meant to be used with users who can connect via
+uses the
+.Xr pf.conf 5
+syntax to change filter and translation rules for an individual
+user or client IP address as long as a user maintains an active
 .Xr ssh 1
-only.
-On startup,
+session, and logs the successful start and end of a session to
+.Xr syslogd 8 .
 .Nm
 retrieves the client's connecting IP address via the
 .Ev SSH_CLIENT
 environment variable and, after performing additional access checks,
 reads a template file to determine what filter and translation rules
-(if any) to add.
-On session exit the same rules that were added at startup are removed.
+(if any) to add, and
+maintains the list of IP addresses of connected users in the
+.Ar authpf_users
+table.
+On session exit the same rules and table entries that were added at startup
+are removed, and all states associated with the client's IP address are purged.
 .Pp
 Each
 .Nm
@@ -185,6 +203,9 @@ It is also possible to configure
 to only allow specific users access.
 This is done by listing their login names, one per line, in
 .Pa /etc/authpf/authpf.allow .
+A group of users can also be indicated by prepending "%" to the group name,
+and all members of a login class can be indicated by prepending "@" to the
+login class name.
 If "*" is found on a line, then all usernames match.
 If
 .Nm
@@ -297,7 +318,8 @@ They have a
 wireless network which they would like to protect from unauthorized use.
 To accomplish this, they create the file
 .Pa /etc/authpf/authpf.allow
-which lists their login ids, one per line.
+which lists their login ids, group prepended with "%", or login class
+prepended with "@", one per line.
 At this point, even if eve could authenticate to
 .Xr sshd 8 ,
 she would not be allowed to use the gateway.
@@ -501,6 +523,31 @@ table <authpf_users> persist
 anchor "authpf/*" from <authpf_users>
 rdr-anchor "authpf/*" from <authpf_users>
 .Ed
+.Pp
+.Sy Tunneled users
+\- normally
+.Nm
+allows only one session per client IP address.
+However in some cases, such as when connections are tunneled via
+.Xr ssh 1
+or
+.Xr ipsec 4 ,
+the connections can be authorized based on the userid of the user instead of
+the client IP address.
+In this case it is appropriate to use
+.Nm authpf-noip
+to allow multiple users behind a NAT gateway to connect.
+In the
+.Pa /etc/authpf/authpf.rules
+example below, the remote user could tunnel a remote desktop session to their
+workstation:
+.Bd -literal
+internal_if="bge0"
+workstation_ip="10.2.3.4"
+
+pass out on $internal_if from (self) to $workstation_ip port 3389 \e
+       user $user_id
+.Ed
 .Sh FILES
 .Bl -tag -width "/etc/authpf/authpf.conf" -compact
 .It Pa /etc/authpf/authpf.conf
@@ -512,7 +559,6 @@ rdr-anchor "authpf/*" from <authpf_users
 .Sh SEE ALSO
 .Xr pf 4 ,
 .Xr pf.conf 5 ,
-.Xr fdescfs 5 ,
 .Xr securelevel 7 ,
 .Xr ftp-proxy 8
 .Sh HISTORY

Modified: projects/bhyve/contrib/pf/authpf/authpf.c
==============================================================================
--- projects/bhyve/contrib/pf/authpf/authpf.c	Thu Jun 30 16:56:55 2011	(r223697)
+++ projects/bhyve/contrib/pf/authpf/authpf.c	Thu Jun 30 17:37:42 2011	(r223698)
@@ -1,4 +1,4 @@
-/*	$OpenBSD: authpf.c,v 1.104 2007/02/24 17:35:08 beck Exp $	*/
+/*	$OpenBSD: authpf.c,v 1.112 2009/01/10 19:08:53 miod Exp $	*/
 
 /*
  * Copyright (C) 1998 - 2007 Bob Beck (beck at openbsd.org).
@@ -19,7 +19,7 @@
 #include <sys/cdefs.h>
 __FBSDID("$FreeBSD$");
 
-#include <sys/param.h>
+#include <sys/types.h>
 #include <sys/file.h>
 #include <sys/ioctl.h>
 #include <sys/socket.h>
@@ -38,6 +38,7 @@ __FBSDID("$FreeBSD$");
 #endif
 #include <login_cap.h>
 #include <pwd.h>
+#include <grp.h>
 #include <signal.h>
 #include <stdio.h>
 #include <stdlib.h>
@@ -48,10 +49,11 @@ __FBSDID("$FreeBSD$");
 #include "pathnames.h"
 
 static int	read_config(FILE *);
-static void	print_message(char *);
-static int	allowed_luser(char *);
-static int	check_luser(char *, char *);
+static void	print_message(const char *);
+static int	allowed_luser(struct passwd *);
+static int	check_luser(const char *, char *);
 static int	remove_stale_rulesets(void);
+static int	recursive_ruleset_purge(char *, char *);
 static int	change_filter(int, const char *, const char *);
 static int	change_table(int, const char *);
 static void	authpf_kill_states(void);
@@ -60,8 +62,10 @@ int	dev;			/* pf device */
 char	anchorname[PF_ANCHOR_NAME_SIZE] = "authpf";
 char	rulesetname[MAXPATHLEN - PF_ANCHOR_NAME_SIZE - 2];
 char	tablename[PF_TABLE_NAME_SIZE] = "authpf_users";
+int	user_ip = 1;	/* controls whether $user_ip is set */
 
 FILE	*pidfp;
+int	pidfd = -1;
 char	 luser[MAXLOGNAME];	/* username */
 char	 ipsrc[256];		/* ip as a string */
 char	 pidfile[MAXPATHLEN];	/* we save pid in this file. */
@@ -75,6 +79,7 @@ static __dead2 void	do_death(int);
 #else
 static __dead void	do_death(int);
 #endif
+extern char *__progname;	/* program name */
 
 /*
  * User shell for authenticating gateways. Sole purpose is to allow
@@ -83,21 +88,24 @@ static __dead void	do_death(int);
  * up. Meant to be used only from ssh(1) connections.
  */
 int
-main(int argc, char *argv[])
+main(void)
 {
-	int		 lockcnt = 0, n, pidfd;
+	int		 lockcnt = 0, n;
 	FILE		*config;
 	struct in6_addr	 ina;
 	struct passwd	*pw;
 	char		*cp;
 	gid_t		 gid;
 	uid_t		 uid;
-	char		*shell;
+	const char	*shell;
 	login_cap_t	*lc;
 
+	if (strcmp(__progname, "-authpf-noip") == 0)
+                user_ip = 0;
+
 	config = fopen(PATH_CONFFILE, "r");
 	if (config == NULL) {
-		syslog(LOG_ERR, "can not open %s (%m)", PATH_CONFFILE);
+		syslog(LOG_ERR, "cannot open %s (%m)", PATH_CONFFILE);
 		exit(1);
 	}
 
@@ -142,23 +150,34 @@ main(int argc, char *argv[])
 	}
 
 	if ((lc = login_getclass(pw->pw_class)) != NULL)
-		shell = (char *)login_getcapstr(lc, "shell", pw->pw_shell,
+		shell = login_getcapstr(lc, "shell", pw->pw_shell,
 		    pw->pw_shell);
 	else
 		shell = pw->pw_shell;
 
+#ifndef __FreeBSD__
 	login_close(lc);
+#endif
 
-	if (strcmp(shell, PATH_AUTHPF_SHELL)) {
+	if (strcmp(shell, PATH_AUTHPF_SHELL) && 
+	    strcmp(shell, PATH_AUTHPF_SHELL_NOIP)) {
 		syslog(LOG_ERR, "wrong shell for user %s, uid %u",
 		    pw->pw_name, pw->pw_uid);
+#ifdef __FreeBSD__
+	login_close(lc);
+#else
 		if (shell != pw->pw_shell)
 			free(shell);
+#endif
 		goto die;
 	}
 
+#ifdef __FreeBSD__
+	login_close(lc);
+#else
 	if (shell != pw->pw_shell)
 		free(shell);
+#endif
 
 	/*
 	 * Paranoia, but this data _does_ come from outside authpf, and
@@ -181,13 +200,22 @@ main(int argc, char *argv[])
 	}
 
 
-	/* Make our entry in /var/authpf as /var/authpf/ipaddr */
-	n = snprintf(pidfile, sizeof(pidfile), "%s/%s", PATH_PIDFILE, ipsrc);
+	/* Make our entry in /var/authpf as ipaddr or username */
+	n = snprintf(pidfile, sizeof(pidfile), "%s/%s",
+	    PATH_PIDFILE, user_ip ? ipsrc : luser);
 	if (n < 0 || (u_int)n >= sizeof(pidfile)) {
 		syslog(LOG_ERR, "path to pidfile too long");
 		goto die;
 	}
 
+	signal(SIGTERM, need_death);
+	signal(SIGINT, need_death);
+	signal(SIGALRM, need_death);
+	signal(SIGPIPE, need_death);
+	signal(SIGHUP, need_death);
+	signal(SIGQUIT, need_death);
+	signal(SIGTSTP, need_death);
+
 	/*
 	 * If someone else is already using this ip, then this person
 	 * wants to switch users - so kill the old process and exit
@@ -241,15 +269,17 @@ main(int argc, char *argv[])
 		}
 
 		/*
-		 * we try to kill the previous process and acquire the lock
+		 * We try to kill the previous process and acquire the lock
 		 * for 10 seconds, trying once a second. if we can't after
-		 * 10 attempts we log an error and give up
+		 * 10 attempts we log an error and give up.
 		 */
-		if (++lockcnt > 10) {
-			syslog(LOG_ERR, "cannot kill previous authpf (pid %d)",
-			    otherpid);
+		if (want_death || ++lockcnt > 10) {
+			if (!want_death)
+				syslog(LOG_ERR, "cannot kill previous authpf (pid %d)",
+				    otherpid);
 			fclose(pidfp);
 			pidfp = NULL;
+			pidfd = -1;
 			goto dogdeath;
 		}
 		sleep(1);
@@ -260,6 +290,7 @@ main(int argc, char *argv[])
 		 */
 		fclose(pidfp);
 		pidfp = NULL;
+		pidfd = -1;
 	} while (1);
 	
 	/* whack the group list */
@@ -277,7 +308,7 @@ main(int argc, char *argv[])
 	}
 	openlog("authpf", LOG_PID | LOG_NDELAY, LOG_DAEMON);
 
-	if (!check_luser(PATH_BAN_DIR, luser) || !allowed_luser(luser)) {
+	if (!check_luser(PATH_BAN_DIR, luser) || !allowed_luser(pw)) {
 		syslog(LOG_INFO, "user %s prohibited", luser);
 		do_death(0);
 	}
@@ -302,19 +333,12 @@ main(int argc, char *argv[])
 		printf("Unable to modify filters\r\n");
 		do_death(0);
 	}
-	if (change_table(1, ipsrc) == -1) {
+	if (user_ip && change_table(1, ipsrc) == -1) {
 		printf("Unable to modify table\r\n");
 		change_filter(0, luser, ipsrc);
 		do_death(0);
 	}
 
-	signal(SIGTERM, need_death);
-	signal(SIGINT, need_death);
-	signal(SIGALRM, need_death);
-	signal(SIGPIPE, need_death);
-	signal(SIGHUP, need_death);
-	signal(SIGQUIT, need_death);
-	signal(SIGTSTP, need_death);
 	while (1) {
 		printf("\r\nHello %s. ", luser);
 		printf("You are authenticated from host \"%s\"\r\n", ipsrc);
@@ -337,8 +361,6 @@ dogdeath:
 	sleep(180); /* them lusers read reaaaaal slow */
 die:
 	do_death(0);
-
-	/* NOTREACHED */
 }
 
 /*
@@ -361,6 +383,8 @@ read_config(FILE *f)
 		}
 		i++;
 		len = strlen(buf);
+		if (len == 0)
+			continue;
 		if (buf[len - 1] != '\n' && !feof(f)) {
 			syslog(LOG_ERR, "line %d too long in %s", i,
 			    PATH_CONFFILE);
@@ -413,7 +437,7 @@ parse_error:
  * they've been bad or we're unavailable.
  */
 static void
-print_message(char *filename)
+print_message(const char *filename)
 {
 	char	 buf[1024];
 	FILE	*f;
@@ -436,6 +460,7 @@ print_message(char *filename)
  * allowed_luser checks to see if user "luser" is allowed to
  * use this gateway by virtue of being listed in an allowed
  * users file, namely /etc/authpf/authpf.allow .
+ * Users may be listed by <username>, %<group>, or @<login_class>.
  *
  * If /etc/authpf/authpf.allow does not exist, then we assume that
  * all users who are allowed in by sshd(8) are permitted to
@@ -444,9 +469,9 @@ print_message(char *filename)
  * the session terminates in the same manner as being banned.
  */
 static int
-allowed_luser(char *luser)
+allowed_luser(struct passwd *pw)
 {
-	char	*buf, *lbuf;
+	char *buf,*lbuf;
 	int	 matched;
 	size_t	 len;
 	FILE	*f;
@@ -476,8 +501,14 @@ allowed_luser(char *luser)
 		 * "public" gateway, such as it is, so let
 		 * everyone use it.
 		 */
+		int gl_init = 0, ngroups = NGROUPS + 1;
+		gid_t groups[NGROUPS + 1];
+
 		lbuf = NULL;
+		matched = 0;
+
 		while ((buf = fgetln(f, &len))) {
+			
 			if (buf[len - 1] == '\n')
 				buf[len - 1] = '\0';
 			else {
@@ -488,7 +519,40 @@ allowed_luser(char *luser)
 				buf = lbuf;
 			}
 
-			matched = strcmp(luser, buf) == 0 || strcmp("*", buf) == 0;
+			if (buf[0] == '@') {
+				/* check login class */
+				if (strcmp(pw->pw_class, buf + 1) == 0)
+					matched++;
+			} else if (buf[0] == '%') {
+				/* check group membership */
+				int cnt; 
+				struct group *group;
+
+				if ((group = getgrnam(buf + 1)) == NULL) {
+					syslog(LOG_ERR,
+					    "invalid group '%s' in %s (%s)",
+					    buf + 1, PATH_ALLOWFILE,
+				 	    strerror(errno));
+					return (0);
+				}
+
+				if (!gl_init) {
+					(void) getgrouplist(pw->pw_name,
+					    pw->pw_gid, groups, &ngroups);
+					gl_init++;
+				}
+			
+				for ( cnt = 0; cnt < ngroups; cnt++) {
+					if (group->gr_gid == groups[cnt]) {
+						matched++;
+						break;

*** DIFF OUTPUT TRUNCATED AT 1000 LINES ***


More information about the svn-src-projects mailing list