Date: Fri, 16 Jan 2004 23:26:59 -0800 (PST) From: Scott Long <scottl@FreeBSD.org> To: Perforce Change Reviews <perforce@freebsd.org> Subject: PERFORCE change 45481 for review Message-ID: <200401170726.i0H7QxmE000882@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=45481 Change 45481 by scottl@scottl-netperf on 2004/01/16 23:26:59 IFC @45479 Affected files ... .. //depot/projects/netperf+sockets/sys/Makefile#2 integrate .. //depot/projects/netperf+sockets/sys/compat/ndis/hal_var.h#2 integrate .. //depot/projects/netperf+sockets/sys/compat/ndis/ndis_var.h#10 integrate .. //depot/projects/netperf+sockets/sys/compat/ndis/ntoskrnl_var.h#4 integrate .. //depot/projects/netperf+sockets/sys/compat/ndis/pe_var.h#4 integrate .. //depot/projects/netperf+sockets/sys/compat/ndis/subr_hal.c#4 integrate .. //depot/projects/netperf+sockets/sys/compat/ndis/subr_ntoskrnl.c#9 integrate .. //depot/projects/netperf+sockets/sys/dev/dpt/dpt_scsi.c#2 integrate .. //depot/projects/netperf+sockets/sys/dev/if_ndis/if_ndis.c#11 integrate .. //depot/projects/netperf+sockets/sys/dev/usb/usb_quirks.c#3 integrate .. //depot/projects/netperf+sockets/sys/dev/usb/usbdevs#8 integrate .. //depot/projects/netperf+sockets/sys/dev/usb/usbdevs.h#8 integrate .. //depot/projects/netperf+sockets/sys/dev/usb/usbdevs_data.h#8 integrate .. //depot/projects/netperf+sockets/sys/fs/unionfs/union_subr.c#2 integrate .. //depot/projects/netperf+sockets/sys/fs/unionfs/union_vnops.c#4 integrate .. //depot/projects/netperf+sockets/sys/kern/init_main.c#3 integrate .. //depot/projects/netperf+sockets/sys/kern/kern_descrip.c#5 integrate .. //depot/projects/netperf+sockets/sys/kern/uipc_usrreq.c#8 integrate .. //depot/projects/netperf+sockets/sys/modules/Makefile#6 integrate .. //depot/projects/netperf+sockets/sys/powerpc/powermac/ata_macio.c#4 integrate .. //depot/projects/netperf+sockets/sys/powerpc/psim/ata_iobus.c#3 integrate .. //depot/projects/netperf+sockets/sys/sys/filedesc.h#4 integrate Differences ... ==== //depot/projects/netperf+sockets/sys/Makefile#2 (text+ko) ==== @@ -1,9 +1,9 @@ -# $FreeBSD: src/sys/Makefile,v 1.28 2003/06/26 03:52:48 peter Exp $ +# $FreeBSD: src/sys/Makefile,v 1.29 2004/01/17 03:28:27 ru Exp $ # The boot loader SUBDIR= boot -# KLD modules build for both a.out and ELF +# Loadable kernel modules .if defined(MODULES_WITH_WORLD) SUBDIR+=modules .endif ==== //depot/projects/netperf+sockets/sys/compat/ndis/hal_var.h#2 (text+ko) ==== @@ -29,12 +29,20 @@ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGE. * - * $FreeBSD: src/sys/compat/ndis/hal_var.h,v 1.1 2003/12/11 22:34:37 wpaul Exp $ + * $FreeBSD: src/sys/compat/ndis/hal_var.h,v 1.2 2004/01/15 21:31:48 wpaul Exp $ */ #ifndef _HAL_VAR_H_ #define _HAL_VAR_H_ +#ifdef __amd64__ +#define NDIS_BUS_SPACE_IO AMD64_BUS_SPACE_IO +#define NDIS_BUS_SPACE_MEM AMD64_BUS_SPACE_MEM +#else +#define NDIS_BUS_SPACE_IO I386_BUS_SPACE_IO +#define NDIS_BUS_SPACE_MEM I386_BUS_SPACE_MEM +#endif + extern image_patch_table hal_functbl[]; #endif /* _HAL_VAR_H_ */ ==== //depot/projects/netperf+sockets/sys/compat/ndis/ndis_var.h#10 (text+ko) ==== @@ -29,7 +29,7 @@ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGE. * - * $FreeBSD: src/sys/compat/ndis/ndis_var.h,v 1.15 2004/01/12 03:49:20 wpaul Exp $ + * $FreeBSD: src/sys/compat/ndis/ndis_var.h,v 1.16 2004/01/16 02:07:04 obrien Exp $ */ #ifndef _NDIS_VAR_H_ @@ -46,7 +46,7 @@ typedef void *ndis_handle; typedef uint32_t ndis_oid; typedef uint32_t ndis_error_code; -typedef uint32_t ndis_kspin_lock; +typedef register_t ndis_kspin_lock; typedef uint8_t ndis_kirql; /* ==== //depot/projects/netperf+sockets/sys/compat/ndis/ntoskrnl_var.h#4 (text+ko) ==== @@ -29,7 +29,7 @@ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGE. * - * $FreeBSD: src/sys/compat/ndis/ntoskrnl_var.h,v 1.4 2003/12/23 04:08:22 wpaul Exp $ + * $FreeBSD: src/sys/compat/ndis/ntoskrnl_var.h,v 1.5 2004/01/16 02:07:04 obrien Exp $ */ #ifndef _NTOSKRNL_VAR_H_ @@ -55,7 +55,28 @@ #define MDL_VA(b) \ ((void *)((char *)((b)->nb_startva) + (b)->nb_byteoffset)) -typedef uint32_t kspin_lock; +/*- + * The ndis_kspin_lock type is called KSPIN_LOCK in MS-Windows. + * According to the Windows DDK header files, KSPIN_LOCK is defined like this: + * typedef ULONG_PTR KSPIN_LOCK; + * + * From basetsd.h (SDK, Feb. 2003): + * typedef [public] unsigned __int3264 ULONG_PTR, *PULONG_PTR; + * typedef unsigned __int64 ULONG_PTR, *PULONG_PTR; + * typedef _W64 unsigned long ULONG_PTR, *PULONG_PTR; + * + * The keyword __int3264 specifies an integral type that has the following + * properties: + * + It is 32-bit on 32-bit platforms + * + It is 64-bit on 64-bit platforms + * + It is 32-bit on the wire for backward compatibility. + * It gets truncated on the sending side and extended appropriately + * (signed or unsigned) on the receiving side. + * + * Thus register_t seems the proper mapping onto FreeBSD for spin locks. + */ + +typedef register_t kspin_lock; struct slist_entry { struct slist_entry *sl_next; ==== //depot/projects/netperf+sockets/sys/compat/ndis/pe_var.h#4 (text+ko) ==== @@ -29,7 +29,7 @@ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGE. * - * $FreeBSD: src/sys/compat/ndis/pe_var.h,v 1.4 2004/01/13 22:49:45 obrien Exp $ + * $FreeBSD: src/sys/compat/ndis/pe_var.h,v 1.6 2004/01/15 21:31:48 wpaul Exp $ */ #ifndef _PE_VAR_H_ @@ -417,9 +417,9 @@ */ #ifdef __amd64__ -#define __stdcall +#define __stdcall #else -#define __stdcall __attribute__((__stdcall__)) +#define __stdcall __attribute__((__stdcall__)) #endif __BEGIN_DECLS ==== //depot/projects/netperf+sockets/sys/compat/ndis/subr_hal.c#4 (text+ko) ==== @@ -31,7 +31,7 @@ */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/sys/compat/ndis/subr_hal.c,v 1.6 2004/01/13 22:49:45 obrien Exp $"); +__FBSDID("$FreeBSD: src/sys/compat/ndis/subr_hal.c,v 1.7 2004/01/15 19:34:56 obrien Exp $"); #include <sys/param.h> #include <sys/types.h> @@ -96,7 +96,7 @@ uint32_t *port; uint32_t val; { - bus_space_write_4(I386_BUS_SPACE_IO, 0x0, (uint32_t)port, val); + bus_space_write_4(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port, val); return; } @@ -105,7 +105,7 @@ uint16_t *port; uint16_t val; { - bus_space_write_2(I386_BUS_SPACE_IO, 0x0, (uint32_t)port, val); + bus_space_write_2(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port, val); return; } @@ -114,7 +114,7 @@ uint8_t *port; uint8_t val; { - bus_space_write_1(I386_BUS_SPACE_IO, 0x0, (uint32_t)port, val); + bus_space_write_1(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port, val); return; } @@ -124,7 +124,7 @@ uint32_t *val; uint32_t cnt; { - bus_space_write_multi_4(I386_BUS_SPACE_IO, 0x0, + bus_space_write_multi_4(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port, val, cnt); return; } @@ -135,7 +135,7 @@ uint16_t *val; uint32_t cnt; { - bus_space_write_multi_2(I386_BUS_SPACE_IO, 0x0, + bus_space_write_multi_2(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port, val, cnt); return; } @@ -146,7 +146,7 @@ uint8_t *val; uint32_t cnt; { - bus_space_write_multi_1(I386_BUS_SPACE_IO, 0x0, + bus_space_write_multi_1(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port, val, cnt); return; } @@ -155,21 +155,21 @@ hal_readport_ushort(port) uint16_t *port; { - return(bus_space_read_2(I386_BUS_SPACE_IO, 0x0, (uint32_t)port)); + return(bus_space_read_2(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port)); } __stdcall static uint32_t hal_readport_ulong(port) uint32_t *port; { - return(bus_space_read_4(I386_BUS_SPACE_IO, 0x0, (uint32_t)port)); + return(bus_space_read_4(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port)); } __stdcall static uint8_t hal_readport_uchar(port) uint8_t *port; { - return(bus_space_read_1(I386_BUS_SPACE_IO, 0x0, (uint32_t)port)); + return(bus_space_read_1(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port)); } __stdcall static void @@ -178,7 +178,7 @@ uint32_t *val; uint32_t cnt; { - bus_space_read_multi_4(I386_BUS_SPACE_IO, 0x0, + bus_space_read_multi_4(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port, val, cnt); return; } @@ -189,7 +189,7 @@ uint16_t *val; uint32_t cnt; { - bus_space_read_multi_2(I386_BUS_SPACE_IO, 0x0, + bus_space_read_multi_2(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port, val, cnt); return; } @@ -200,7 +200,7 @@ uint8_t *val; uint32_t cnt; { - bus_space_read_multi_1(I386_BUS_SPACE_IO, 0x0, + bus_space_read_multi_1(NDIS_BUS_SPACE_IO, 0x0, (bus_size_t)port, val, cnt); return; } ==== //depot/projects/netperf+sockets/sys/compat/ndis/subr_ntoskrnl.c#9 (text+ko) ==== @@ -31,7 +31,7 @@ */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/sys/compat/ndis/subr_ntoskrnl.c,v 1.15 2004/01/13 22:49:45 obrien Exp $"); +__FBSDID("$FreeBSD: src/sys/compat/ndis/subr_ntoskrnl.c,v 1.17 2004/01/15 21:31:48 wpaul Exp $"); #include <sys/ctype.h> #include <sys/param.h> @@ -56,6 +56,7 @@ #include <sys/rman.h> #include <compat/ndis/pe_var.h> +#include <compat/ndis/hal_var.h> #include <compat/ndis/resource_var.h> #include <compat/ndis/ndis_var.h> #include <compat/ndis/ntoskrnl_var.h> @@ -282,7 +283,7 @@ uint16_t *reg; uint16_t val; { - bus_space_write_2(I386_BUS_SPACE_MEM, 0x0, (uint32_t)reg, val); + bus_space_write_2(NDIS_BUS_SPACE_MEM, 0x0, (bus_size_t)reg, val); return; } @@ -290,7 +291,7 @@ ntoskrnl_readreg_ushort(reg) uint16_t *reg; { - return(bus_space_read_2(I386_BUS_SPACE_MEM, 0x0, (uint32_t)reg)); + return(bus_space_read_2(NDIS_BUS_SPACE_MEM, 0x0, (bus_size_t)reg)); } __stdcall static void @@ -298,7 +299,7 @@ uint32_t *reg; uint32_t val; { - bus_space_write_4(I386_BUS_SPACE_MEM, 0x0, (uint32_t)reg, val); + bus_space_write_4(NDIS_BUS_SPACE_MEM, 0x0, (bus_size_t)reg, val); return; } @@ -306,14 +307,14 @@ ntoskrnl_readreg_ulong(reg) uint32_t *reg; { - return(bus_space_read_4(I386_BUS_SPACE_MEM, 0x0, (uint32_t)reg)); + return(bus_space_read_4(NDIS_BUS_SPACE_MEM, 0x0, (bus_size_t)reg)); } __stdcall static uint8_t ntoskrnl_readreg_uchar(reg) uint8_t *reg; { - return(bus_space_read_1(I386_BUS_SPACE_MEM, 0x0, (uint32_t)reg)); + return(bus_space_read_1(NDIS_BUS_SPACE_MEM, 0x0, (bus_size_t)reg)); } __stdcall static void @@ -321,7 +322,7 @@ uint8_t *reg; uint8_t val; { - bus_space_write_1(I386_BUS_SPACE_MEM, 0x0, (uint32_t)reg, val); + bus_space_write_1(NDIS_BUS_SPACE_MEM, 0x0, (bus_size_t)reg, val); return; } ==== //depot/projects/netperf+sockets/sys/dev/dpt/dpt_scsi.c#2 (text+ko) ==== @@ -28,7 +28,7 @@ */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/sys/dev/dpt/dpt_scsi.c,v 1.45 2003/08/24 17:46:04 obrien Exp $"); +__FBSDID("$FreeBSD: src/sys/dev/dpt/dpt_scsi.c,v 1.46 2004/01/17 05:57:52 mdodd Exp $"); /* * dpt_scsi.c: SCSI dependant code for the DPT driver @@ -46,7 +46,7 @@ * arrays that span controllers (Wow!). */ -#ident "$FreeBSD: src/sys/dev/dpt/dpt_scsi.c,v 1.45 2003/08/24 17:46:04 obrien Exp $" +#ident "$FreeBSD: src/sys/dev/dpt/dpt_scsi.c,v 1.46 2004/01/17 05:57:52 mdodd Exp $" #define _DPT_C_ @@ -1553,8 +1553,19 @@ dpt->sims[i] = cam_sim_alloc(dpt_action, dpt_poll, "dpt", dpt, dpt->unit, /*untagged*/2, /*tagged*/dpt->max_dccbs, devq); + if (dpt->sims[i] == NULL) { + if (i == 0) + cam_simq_free(devq); + else + printf( "%s(): Unable to attach bus %d " + "due to resource shortage\n", + __func__, i); + break; + } + if (xpt_bus_register(dpt->sims[i], i) != CAM_SUCCESS) { cam_sim_free(dpt->sims[i], /*free_devq*/i == 0); + dpt->sims[i] = NULL; break; } @@ -1564,6 +1575,7 @@ CAM_LUN_WILDCARD) != CAM_REQ_CMP) { xpt_bus_deregister(cam_sim_path(dpt->sims[i])); cam_sim_free(dpt->sims[i], /*free_devq*/i == 0); + dpt->sims[i] = NULL; break; } ==== //depot/projects/netperf+sockets/sys/dev/if_ndis/if_ndis.c#11 (text+ko) ==== @@ -31,7 +31,7 @@ */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/sys/dev/if_ndis/if_ndis.c,v 1.27 2004/01/12 21:04:43 wpaul Exp $"); +__FBSDID("$FreeBSD: src/sys/dev/if_ndis/if_ndis.c,v 1.28 2004/01/15 21:31:49 wpaul Exp $"); #include "opt_bdg.h" @@ -93,8 +93,6 @@ { 0, 0, 0, NULL } }; -#define __stdcall __attribute__((__stdcall__)) - static int ndis_probe (device_t); static int ndis_attach (device_t); static int ndis_detach (device_t); ==== //depot/projects/netperf+sockets/sys/dev/usb/usb_quirks.c#3 (text+ko) ==== @@ -38,7 +38,7 @@ */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/sys/dev/usb/usb_quirks.c,v 1.35 2004/01/13 21:42:31 green Exp $"); +__FBSDID("$FreeBSD: src/sys/dev/usb/usb_quirks.c,v 1.36 2004/01/16 15:29:27 sanpei Exp $"); #include <sys/param.h> #include <sys/systm.h> @@ -105,6 +105,8 @@ { USB_VENDOR_LOGITECH, USB_PRODUCT_LOGITECH_WMRPAD, ANY, { UQ_NO_STRINGS }}, { USB_VENDOR_QUALCOMM, USB_PRODUCT_QUALCOMM_CDMA_MSM, ANY, { UQ_ASSUME_CM_OVER_DATA }}, + { USB_VENDOR_SUNTAC, USB_PRODUCT_SUNTAC_AS64LX, + 0x100, { UQ_ASSUME_CM_OVER_DATA }}, { 0, 0, 0, { 0 } } }; ==== //depot/projects/netperf+sockets/sys/dev/usb/usbdevs#8 (text+ko) ==== @@ -1,4 +1,4 @@ -$FreeBSD: src/sys/dev/usb/usbdevs,v 1.156 2004/01/13 21:42:32 green Exp $ +$FreeBSD: src/sys/dev/usb/usbdevs,v 1.157 2004/01/16 15:29:27 sanpei Exp $ /* * Copyright (c) 1998, 1999, 2000 The NetBSD Foundation, Inc. @@ -1184,9 +1184,10 @@ /* SUN Corporation products */ product SUNTAC DS96L 0x0003 SUNTAC U-Cable type D2 -product SUNTAC IS96U 0x000a SUNTAC Ir-Trinity product SUNTAC PS64P1 0x0005 SUNTAC U-Cable type P1 product SUNTAC VS10U 0x0009 SUNTAC Slipper U +product SUNTAC IS96U 0x000a SUNTAC Ir-Trinity +product SUNTAC AS64LX 0x000b SUNTAC U-Cable type A3 /* Sun Microsystems products */ product SUN KEYBOARD 0x0005 Type 6 USB keyboard ==== //depot/projects/netperf+sockets/sys/dev/usb/usbdevs.h#8 (text+ko) ==== @@ -1,10 +1,10 @@ -/* $FreeBSD: src/sys/dev/usb/usbdevs.h,v 1.163 2004/01/13 21:42:32 green Exp $ */ +/* $FreeBSD: src/sys/dev/usb/usbdevs.h,v 1.164 2004/01/16 15:31:20 sanpei Exp $ */ /* * THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT. * * generated from: - * FreeBSD: src/sys/dev/usb/usbdevs,v 1.155 2004/01/12 12:47:36 sanpei Exp + * FreeBSD: src/sys/dev/usb/usbdevs,v 1.157 2004/01/16 15:29:27 sanpei Exp */ /* @@ -1191,9 +1191,10 @@ /* SUN Corporation products */ #define USB_PRODUCT_SUNTAC_DS96L 0x0003 /* SUNTAC U-Cable type D2 */ -#define USB_PRODUCT_SUNTAC_IS96U 0x000a /* SUNTAC Ir-Trinity */ #define USB_PRODUCT_SUNTAC_PS64P1 0x0005 /* SUNTAC U-Cable type P1 */ #define USB_PRODUCT_SUNTAC_VS10U 0x0009 /* SUNTAC Slipper U */ +#define USB_PRODUCT_SUNTAC_IS96U 0x000a /* SUNTAC Ir-Trinity */ +#define USB_PRODUCT_SUNTAC_AS64LX 0x000b /* SUNTAC U-Cable type A3 */ /* Sun Microsystems products */ #define USB_PRODUCT_SUN_KEYBOARD 0x0005 /* Type 6 USB keyboard */ ==== //depot/projects/netperf+sockets/sys/dev/usb/usbdevs_data.h#8 (text+ko) ==== @@ -1,10 +1,10 @@ -/* $FreeBSD: src/sys/dev/usb/usbdevs_data.h,v 1.163 2004/01/13 21:42:32 green Exp $ */ +/* $FreeBSD: src/sys/dev/usb/usbdevs_data.h,v 1.164 2004/01/16 15:31:20 sanpei Exp $ */ /* * THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT. * * generated from: - * FreeBSD: src/sys/dev/usb/usbdevs,v 1.155 2004/01/12 12:47:36 sanpei Exp + * FreeBSD: src/sys/dev/usb/usbdevs,v 1.157 2004/01/16 15:29:27 sanpei Exp */ /* @@ -2938,22 +2938,28 @@ "SUNTAC U-Cable type D2", }, { - USB_VENDOR_SUNTAC, USB_PRODUCT_SUNTAC_IS96U, + USB_VENDOR_SUNTAC, USB_PRODUCT_SUNTAC_PS64P1, + 0, + "SUN Corporation", + "SUNTAC U-Cable type P1", + }, + { + USB_VENDOR_SUNTAC, USB_PRODUCT_SUNTAC_VS10U, 0, "SUN Corporation", - "SUNTAC Ir-Trinity", + "SUNTAC Slipper U", }, { - USB_VENDOR_SUNTAC, USB_PRODUCT_SUNTAC_PS64P1, + USB_VENDOR_SUNTAC, USB_PRODUCT_SUNTAC_IS96U, 0, "SUN Corporation", - "SUNTAC U-Cable type P1", + "SUNTAC Ir-Trinity", }, { - USB_VENDOR_SUNTAC, USB_PRODUCT_SUNTAC_VS10U, + USB_VENDOR_SUNTAC, USB_PRODUCT_SUNTAC_AS64LX, 0, "SUN Corporation", - "SUNTAC Slipper U", + "SUNTAC U-Cable type A3", }, { USB_VENDOR_SUN, USB_PRODUCT_SUN_KEYBOARD, ==== //depot/projects/netperf+sockets/sys/fs/unionfs/union_subr.c#2 (text+ko) ==== @@ -35,7 +35,7 @@ * SUCH DAMAGE. * * @(#)union_subr.c 8.20 (Berkeley) 5/20/95 - * $FreeBSD: src/sys/fs/unionfs/union_subr.c,v 1.75 2003/07/26 07:32:21 phk Exp $ + * $FreeBSD: src/sys/fs/unionfs/union_subr.c,v 1.77 2004/01/16 22:54:33 green Exp $ */ #include <sys/param.h> @@ -1155,38 +1155,31 @@ return (VOP_CLOSE(vp, fmode, cred, td)); } -#if 0 - /* * union_removed_upper: * - * called with union_node unlocked. XXX + * An upper-only file/directory has been removed; un-cache it so + * that unionfs vnode gets reclaimed and the last uppervp reference + * disappears. + * + * Called with union_node unlocked. */ void union_removed_upper(un) struct union_node *un; { - struct thread *td = curthread; /* XXX */ - struct vnode **vpp; + if (un->un_flags & UN_CACHED) { + int hash = UNION_HASH(un->un_uppervp, un->un_lowervp); - /* - * Do not set the uppervp to NULLVP. If lowervp is NULLVP, - * union node will have neither uppervp nor lowervp. We remove - * the union node from cache, so that it will not be referrenced. - */ - union_newupper(un, NULLVP); - if (un->un_dircache != NULL) - union_dircache_free(un); - - if (un->un_flags & UN_CACHED) { + while (union_list_lock(hash)) + continue; un->un_flags &= ~UN_CACHED; LIST_REMOVE(un, un_cache); + union_list_unlock(hash); } } -#endif - /* * Determine whether a whiteout is needed * during a remove/rmdir operation. ==== //depot/projects/netperf+sockets/sys/fs/unionfs/union_vnops.c#4 (text+ko) ==== @@ -35,7 +35,7 @@ * SUCH DAMAGE. * * @(#)union_vnops.c 8.32 (Berkeley) 6/23/95 - * $FreeBSD: src/sys/fs/unionfs/union_vnops.c,v 1.104 2004/01/03 00:36:46 tjr Exp $ + * $FreeBSD: src/sys/fs/unionfs/union_vnops.c,v 1.106 2004/01/16 22:55:25 green Exp $ */ #include <sys/param.h> @@ -1224,12 +1224,12 @@ if ((uppervp = union_lock_upper(un, td)) != NULLVP) { if (union_dowhiteout(un, cnp->cn_cred, td)) cnp->cn_flags |= DOWHITEOUT; - error = VOP_REMOVE(upperdvp, uppervp, cnp); -#if 0 - /* XXX */ + if (cnp->cn_flags & DOWHITEOUT) /* XXX fs corruption */ + error = EOPNOTSUPP; + else + error = VOP_REMOVE(upperdvp, uppervp, cnp); if (!error) union_removed_upper(un); -#endif union_unlock_upper(uppervp, td); } else { error = union_mkwhiteout( @@ -1541,7 +1541,12 @@ if ((uppervp = union_lock_upper(un, td)) != NULLVP) { if (union_dowhiteout(un, cnp->cn_cred, td)) cnp->cn_flags |= DOWHITEOUT; - error = VOP_RMDIR(upperdvp, uppervp, ap->a_cnp); + if (cnp->cn_flags & DOWHITEOUT) /* XXX fs corruption */ + error = EOPNOTSUPP; + else + error = VOP_RMDIR(upperdvp, uppervp, ap->a_cnp); + if (!error) + union_removed_upper(un); union_unlock_upper(uppervp, td); } else { error = union_mkwhiteout( ==== //depot/projects/netperf+sockets/sys/kern/init_main.c#3 (text+ko) ==== @@ -42,7 +42,7 @@ */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/sys/kern/init_main.c,v 1.239 2004/01/15 10:15:03 des Exp $"); +__FBSDID("$FreeBSD: src/sys/kern/init_main.c,v 1.240 2004/01/16 20:29:23 rwatson Exp $"); #include "opt_init_path.h" #include "opt_mac.h" @@ -683,6 +683,7 @@ error = fork1(&thread0, RFFDG | RFPROC | RFSTOPPED, 0, &initproc); if (error) panic("cannot fork init: %d\n", error); + KASSERT(initproc->p_pid == 1, ("create_init: initproc->p_pid != 1")); /* divorce init's credentials from the kernel's */ newcred = crget(); PROC_LOCK(initproc); ==== //depot/projects/netperf+sockets/sys/kern/kern_descrip.c#5 (text+ko) ==== @@ -39,7 +39,7 @@ */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/sys/kern/kern_descrip.c,v 1.219 2004/01/15 10:15:03 des Exp $"); +__FBSDID("$FreeBSD: src/sys/kern/kern_descrip.c,v 1.223 2004/01/17 00:58:36 des Exp $"); #include "opt_compat.h" @@ -599,12 +599,10 @@ if (type == DUP_FIXED) { if (new >= fdp->fd_nfiles) fdgrowtable(fdp, new + 1); - KASSERT(new < fdp->fd_nfiles, - ("fdgrowtable() failed to grow table")); if (fdp->fd_ofiles[new] == NULL) fdused(fdp, new); } else { - if ((error = fdalloc(td, &new)) != 0) { + if ((error = fdalloc(td, new, &new)) != 0) { FILEDESC_UNLOCK(fdp); fdrop(fp, td); return (error); @@ -1207,7 +1205,7 @@ * Allocate a file descriptor for the process. */ int -fdalloc(struct thread *td, int *result) +fdalloc(struct thread *td, int minfd, int *result) { struct proc *p = td->td_proc; struct filedesc *fdp = p->p_fd; @@ -1224,14 +1222,13 @@ * may drop the filedesc lock, so we're in a race. */ for (;;) { - fd = fd_first_free(fdp, fdp->fd_freefile, fdp->fd_nfiles); + fd = fd_first_free(fdp, minfd, fdp->fd_nfiles); if (fd >= maxfd) return (EMFILE); if (fd < fdp->fd_nfiles) break; fdgrowtable(fdp, min(fdp->fd_nfiles * 2, maxfd)); } - FILEDESC_LOCK_ASSERT(fdp, MA_OWNED); /* * Perform some sanity checks, then mark the file descriptor as @@ -1329,7 +1326,7 @@ LIST_INSERT_HEAD(&filehead, fp, f_list); } sx_xunlock(&filelist_lock); - if ((error = fdalloc(td, &i))) { + if ((error = fdalloc(td, 0, &i))) { FILEDESC_UNLOCK(p->p_fd); fdrop(fp, td); if (resultfp) @@ -1374,8 +1371,10 @@ FILEDESC_LOCK_ASSERT(fdp, MA_OWNED); + FILEDESC_UNLOCK(fdp); MALLOC(newfdp, struct filedesc0 *, sizeof(struct filedesc0), M_FILEDESC, M_WAITOK | M_ZERO); + FILEDESC_LOCK(fdp); mtx_init(&newfdp->fd_fd.fd_mtx, FILEDESC_LOCK_DESC, NULL, MTX_DEF); newfdp->fd_fd.fd_cdir = fdp->fd_cdir; if (newfdp->fd_fd.fd_cdir) @@ -1429,11 +1428,13 @@ FILEDESC_LOCK_ASSERT(fdp, MA_OWNED); newfdp = fdinit(fdp); - FILEDESC_LOCK(newfdp); - if (fdp->fd_lastfile >= newfdp->fd_nfiles) + while (fdp->fd_lastfile >= newfdp->fd_nfiles) { + FILEDESC_UNLOCK(fdp); + FILEDESC_LOCK(newfdp); fdgrowtable(newfdp, fdp->fd_lastfile + 1); - KASSERT(newfdp->fd_nfiles > fdp->fd_lastfile, - ("fdgrowtable() failed to grow table")); + FILEDESC_UNLOCK(newfdp); + FILEDESC_LOCK(fdp); + } /* copy everything except kqueue descriptors */ newfdp->fd_freefile = -1; for (i = 0; i <= fdp->fd_lastfile; ++i) { @@ -1441,7 +1442,6 @@ fdp->fd_ofiles[i]->f_type != DTYPE_KQUEUE) { newfdp->fd_ofiles[i] = fdp->fd_ofiles[i]; newfdp->fd_ofileflags[i] = fdp->fd_ofileflags[i]; - fdused(newfdp, i); fhold(newfdp->fd_ofiles[i]); newfdp->fd_lastfile = i; } else { @@ -1449,10 +1449,16 @@ newfdp->fd_freefile = i; } } + FILEDESC_UNLOCK(fdp); + FILEDESC_LOCK(newfdp); + for (i = 0; i <= newfdp->fd_lastfile; ++i) + if (newfdp->fd_ofiles[i] != NULL) + fdused(newfdp, i); + FILEDESC_UNLOCK(newfdp); + FILEDESC_LOCK(fdp); if (newfdp->fd_freefile == -1) newfdp->fd_freefile = i; newfdp->fd_cmask = fdp->fd_cmask; - FILEDESC_UNLOCK(newfdp); return (newfdp); } ==== //depot/projects/netperf+sockets/sys/kern/uipc_usrreq.c#8 (text+ko) ==== @@ -34,7 +34,7 @@ */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/sys/kern/uipc_usrreq.c,v 1.112 2003/11/18 00:39:03 rwatson Exp $"); +__FBSDID("$FreeBSD: src/sys/kern/uipc_usrreq.c,v 1.115 2004/01/17 00:59:04 des Exp $"); #include "opt_mac.h" @@ -1204,7 +1204,7 @@ fdp = (int *) CMSG_DATA(mtod(*controlp, struct cmsghdr *)); for (i = 0; i < newfds; i++) { - if (fdalloc(td, &f)) + if (fdalloc(td, 0, &f)) panic("unp_externalize fdalloc failed"); fp = *rp++; td->td_proc->p_fd->fd_ofiles[f] = fp; ==== //depot/projects/netperf+sockets/sys/modules/Makefile#6 (text+ko) ==== @@ -1,33 +1,49 @@ -# $FreeBSD: src/sys/modules/Makefile,v 1.363 2004/01/11 09:15:13 nyan Exp $ +# $FreeBSD: src/sys/modules/Makefile,v 1.364 2004/01/16 15:55:29 ru Exp $ -.if !defined(NOCRYPT) || defined(ALL_MODULES) -.if exists(${.CURDIR}/../opencrypto) -_crypto= crypto -_cryptodev= cryptodev -.endif -.if exists(${.CURDIR}/../crypto) -_random= random -.endif -.endif +# pcic -- currently broken and being worked on out of tree. +# oldcard -- specialized use for debugging only. +# owi -- totally unsupported for debugging only. -SUBDIR= accf_data \ +SUBDIR= ${_3dfx} \ + ${_aac} \ + accf_data \ accf_http \ + ${_acpi} \ + ${_agp} \ aha \ + ${_aic} \ aic7xxx \ aio \ + ${_amd} \ amr \ an \ + ${_aout} \ + ${_apm} \ + ${_ar} \ + ${_arcnet} \ + ${_asr} \ ath \ + ${_ath_hal} \ aue \ + ${_awi} \ axe \ bfe \ bge \ + ${_bios} \ + ${_bktr} \ bridge \ cam \ + ${_canbepm} \ + ${_canbus} \ + ${_cardbus} \ + ${_cbb} \ cd9660 \ cd9660_iconv \ + ${_ciss} \ + ${_cm} \ coda \ coda5 \ + ${_coff} \ ${_crypto} \ ${_cryptodev} \ cue \ @@ -36,18 +52,37 @@ dcons_crom \ de \ digi \ + ${_dpt} \ + ${_drm} \ dummynet \ + ${_ed} \ + ${_el} \ + ${_elink} \ + ${_em} \ en \ + ${_ep} \ + ${_ex} \ + ${_exca} \ + ${_ext2fs} \ fatm \ fdc \ fdescfs \ + ${_fe} \ firewire \ fxp \ + ${_gem} \ geom \ gx \ harp \ hatm \ + ${_hfa} \ hifn \ + ${_hme} \ + ${_i2c} \ + ${_ibcs2} \ + ${_ida} \ + ${_idt} \ + ${_ie} \ if_disc \ if_ef \ if_faith \ @@ -59,9 +94,12 @@ if_tap \ if_tun \ if_vlan \ + ${_iir} \ ip6fw \ + ${_ipfilter} \ + ipfw \ ip_mroute_mod \ - ipfw \ + ${_ips} \ isp \ ispfw \ joy \ @@ -70,6 +108,9 @@ libiconv \ libmbpool \ libmchain \ + ${_linprocfs} \ + ${_linux} \ + ${_lnc} \ lpt \ mac_biba \ mac_bsdextended \ @@ -86,20 +127,34 @@ md \ mii \ mlx \ + ${_mly} \ mpt \ msdosfs \ msdosfs_iconv \ my \ + ${_ncp} \ + ${_ncv} \ + ${_ndis} \ + ${_netgraph} \ nfsclient \ nfsserver \ nge \ nmdm \ + ${_nsp} \ ntfs \ ntfs_iconv \ + ${_null} \ nullfs \ + ${_nwfs} \ + ${_oltr} \ + ${_osf1} \ patm \ + ${_pccard} \ + ${_pcfclock} \ pcn \ + ${_pecoff} \ plip \ + ${_pmc} \ portalfs \ ppbus \ ppi \ @@ -109,21 +164,36 @@ pst \ raidframe \ ${_random} \ + ${_ray} \ rc \ rc4 \ re \ rl \ rp \ rue \ + ${_s3} \ + ${_safe} \ + ${_sbni} \ sbsh \ scd \ + ${_scsi_low} \ sf \ sis \ sk \ + ${_smbfs} \ sn \ + ${_snc} \ snp \ + ${_sound} \ + ${_speaker} \ + ${_splash} \ + ${_sppp} \ + ${_sr} \ ste \ + ${_stg} \ + ${_streams} \ sym \ + ${_syscons} \ sysvipc \ ti \ tl \ @@ -139,6 +209,7 @@ udf \ udf_iconv \ >>> TRUNCATED FOR MAIL (1000 lines) <<<
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200401170726.i0H7QxmE000882>