Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 6 Jul 2004 07:06:04 GMT
From:      Julian Elischer <julian@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 56594 for review
Message-ID:  <200407060706.i66764tE009904@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=56594

Change 56594 by julian@julian_jules1 on 2004/07/06 07:05:14

	IFC
	still need to do kern_switch.c by hand

Affected files ...

.. //depot/projects/nsched/sys/alpha/alpha/pmap.c#6 integrate
.. //depot/projects/nsched/sys/alpha/include/pmap.h#6 integrate
.. //depot/projects/nsched/sys/amd64/amd64/pmap.c#12 integrate
.. //depot/projects/nsched/sys/arm/arm/pmap.c#3 integrate
.. //depot/projects/nsched/sys/boot/common/ufsread.c#2 integrate
.. //depot/projects/nsched/sys/coda/coda_subr.c#2 integrate
.. //depot/projects/nsched/sys/conf/NOTES#9 integrate
.. //depot/projects/nsched/sys/conf/files#15 integrate
.. //depot/projects/nsched/sys/conf/options#10 integrate
.. //depot/projects/nsched/sys/dev/acpica/acpi_pcib_acpi.c#6 integrate
.. //depot/projects/nsched/sys/dev/fdc/fdc.c#4 integrate
.. //depot/projects/nsched/sys/dev/hifn/hifn7751.c#3 integrate
.. //depot/projects/nsched/sys/dev/nmdm/nmdm.c#7 integrate
.. //depot/projects/nsched/sys/dev/pcf/pcfvar.h#2 integrate
.. //depot/projects/nsched/sys/dev/re/if_re.c#6 integrate
.. //depot/projects/nsched/sys/dev/sound/pci/via82c686.c#2 integrate
.. //depot/projects/nsched/sys/dev/usb/usbdevs#8 integrate
.. //depot/projects/nsched/sys/fs/msdosfs/msdosfs_fileno.c#1 branch
.. //depot/projects/nsched/sys/fs/msdosfs/msdosfs_vfsops.c#3 integrate
.. //depot/projects/nsched/sys/fs/msdosfs/msdosfs_vnops.c#2 integrate
.. //depot/projects/nsched/sys/fs/msdosfs/msdosfsmount.h#3 integrate
.. //depot/projects/nsched/sys/geom/concat/g_concat.c#4 integrate
.. //depot/projects/nsched/sys/geom/concat/g_concat.h#3 integrate
.. //depot/projects/nsched/sys/geom/geom_slice.c#4 integrate
.. //depot/projects/nsched/sys/geom/label/g_label.c#2 integrate
.. //depot/projects/nsched/sys/geom/label/g_label.h#2 integrate
.. //depot/projects/nsched/sys/geom/stripe/g_stripe.c#2 integrate
.. //depot/projects/nsched/sys/geom/stripe/g_stripe.h#2 integrate
.. //depot/projects/nsched/sys/geom/vinum/geom_vinum.c#4 integrate
.. //depot/projects/nsched/sys/gnu/ext2fs/ext2_vfsops.c#4 integrate
.. //depot/projects/nsched/sys/i386/acpica/acpi_wakeup.c#3 integrate
.. //depot/projects/nsched/sys/i386/i386/busdma_machdep.c#2 integrate
.. //depot/projects/nsched/sys/i386/i386/nexus.c#5 integrate
.. //depot/projects/nsched/sys/i386/i386/pmap.c#10 integrate
.. //depot/projects/nsched/sys/i386/isa/isa.c#3 integrate
.. //depot/projects/nsched/sys/i386/isa/isa.h#3 integrate
.. //depot/projects/nsched/sys/i386/isa/isa_dma.c#3 integrate
.. //depot/projects/nsched/sys/i386/linux/linux_ptrace.c#2 integrate
.. //depot/projects/nsched/sys/i386/pci/pci_cfgreg.c#3 integrate
.. //depot/projects/nsched/sys/i4b/driver/i4b_ing.c#4 integrate
.. //depot/projects/nsched/sys/ia64/ia64/pmap.c#7 integrate
.. //depot/projects/nsched/sys/isa/orm.c#2 integrate
.. //depot/projects/nsched/sys/isofs/cd9660/cd9660_lookup.c#3 integrate
.. //depot/projects/nsched/sys/isofs/cd9660/cd9660_node.c#4 integrate
.. //depot/projects/nsched/sys/isofs/cd9660/cd9660_rrip.c#4 integrate
.. //depot/projects/nsched/sys/isofs/cd9660/cd9660_rrip.h#3 integrate
.. //depot/projects/nsched/sys/isofs/cd9660/cd9660_vfsops.c#4 integrate
.. //depot/projects/nsched/sys/kern/kern_event.c#4 integrate
.. //depot/projects/nsched/sys/kern/sched_4bsd.c#23 edit
.. //depot/projects/nsched/sys/kern/sched_ule.c#11 integrate
.. //depot/projects/nsched/sys/kern/uipc_socket.c#9 integrate
.. //depot/projects/nsched/sys/kern/vfs_bio.c#5 integrate
.. //depot/projects/nsched/sys/kern/vfs_default.c#3 integrate
.. //depot/projects/nsched/sys/kern/vfs_mount.c#5 integrate
.. //depot/projects/nsched/sys/kern/vfs_subr.c#8 integrate
.. //depot/projects/nsched/sys/modules/msdosfs/Makefile#2 integrate
.. //depot/projects/nsched/sys/net/bpf.c#6 integrate
.. //depot/projects/nsched/sys/net/bridge.c#5 integrate
.. //depot/projects/nsched/sys/net/if_disc.c#4 integrate
.. //depot/projects/nsched/sys/net/if_faith.c#6 integrate
.. //depot/projects/nsched/sys/net/if_gif.c#6 integrate
.. //depot/projects/nsched/sys/net/if_gre.c#5 integrate
.. //depot/projects/nsched/sys/net/if_vlan.c#6 integrate
.. //depot/projects/nsched/sys/net/rtsock.c#5 integrate
.. //depot/projects/nsched/sys/netgraph/ng_async.c#3 integrate
.. //depot/projects/nsched/sys/netgraph/ng_eiface.c#5 integrate
.. //depot/projects/nsched/sys/netgraph/ng_fec.c#6 integrate
.. //depot/projects/nsched/sys/netgraph/ng_gif_demux.c#3 integrate
.. //depot/projects/nsched/sys/netgraph/ng_iface.c#4 integrate
.. //depot/projects/nsched/sys/netgraph/ng_sppp.c#4 integrate
.. //depot/projects/nsched/sys/nfs4client/nfs4_vfsops.c#3 integrate
.. //depot/projects/nsched/sys/nfsclient/nfs_subs.c#5 integrate
.. //depot/projects/nsched/sys/nfsclient/nfs_vfsops.c#3 integrate
.. //depot/projects/nsched/sys/nfsserver/nfs_srvcache.c#4 integrate
.. //depot/projects/nsched/sys/pci/if_dc.c#6 integrate
.. //depot/projects/nsched/sys/pci/if_de.c#5 integrate
.. //depot/projects/nsched/sys/pci/if_devar.h#2 integrate
.. //depot/projects/nsched/sys/pci/if_rl.c#7 integrate
.. //depot/projects/nsched/sys/pci/if_rlreg.h#4 integrate
.. //depot/projects/nsched/sys/pci/if_sf.c#5 integrate
.. //depot/projects/nsched/sys/pci/if_ti.c#4 integrate
.. //depot/projects/nsched/sys/pci/if_xl.c#6 integrate
.. //depot/projects/nsched/sys/pci/if_xlreg.h#2 integrate
.. //depot/projects/nsched/sys/powerpc/ofw/ofw_syscons.c#3 integrate
.. //depot/projects/nsched/sys/powerpc/ofw/ofw_syscons.h#3 integrate
.. //depot/projects/nsched/sys/powerpc/powerpc/pmap.c#5 integrate
.. //depot/projects/nsched/sys/sparc64/ebus/ebus.c#5 integrate
.. //depot/projects/nsched/sys/sparc64/fhc/fhc.c#3 integrate
.. //depot/projects/nsched/sys/sparc64/pci/psycho.c#5 integrate
.. //depot/projects/nsched/sys/sparc64/sbus/sbus.c#5 integrate
.. //depot/projects/nsched/sys/sparc64/sparc64/iommu.c#5 integrate
.. //depot/projects/nsched/sys/sparc64/sparc64/nexus.c#5 integrate
.. //depot/projects/nsched/sys/sys/event.h#2 integrate
.. //depot/projects/nsched/sys/sys/mount.h#5 integrate
.. //depot/projects/nsched/sys/sys/vnode.h#6 integrate
.. //depot/projects/nsched/sys/ufs/ffs/ffs_snapshot.c#5 integrate
.. //depot/projects/nsched/sys/ufs/ffs/ffs_vfsops.c#5 integrate
.. //depot/projects/nsched/sys/ufs/ufs/ufs_quota.c#3 integrate
.. //depot/projects/nsched/sys/vm/swap_pager.c#6 integrate
.. //depot/projects/nsched/sys/vm/uma_core.c#4 integrate

Differences ...

==== //depot/projects/nsched/sys/alpha/alpha/pmap.c#6 (text+ko) ====

@@ -148,7 +148,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/alpha/alpha/pmap.c,v 1.150 2004/06/15 19:28:39 alc Exp $");
+__FBSDID("$FreeBSD: src/sys/alpha/alpha/pmap.c,v 1.152 2004/07/05 23:18:48 alc Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -520,6 +520,7 @@
 	/*
 	 * Initialize the kernel pmap (which is statically allocated).
 	 */
+	PMAP_LOCK_INIT(kernel_pmap);
 	kernel_pmap->pm_lev1 = Lev1map;
 	kernel_pmap->pm_active = ~0;
 	kernel_pmap->pm_asn[alpha_pal_whami()].asn = 0;
@@ -741,10 +742,8 @@
  *		Extract the physical page address associated
  *		with the given map/virtual_address pair.
  */
-vm_offset_t 
-pmap_extract(pmap, va)
-	register pmap_t pmap;
-	vm_offset_t va;
+vm_paddr_t
+pmap_extract(pmap_t pmap, vm_offset_t va)
 {
 	pt_entry_t* pte = pmap_lev3pte(pmap, va);
 	if (pte)
@@ -988,6 +987,7 @@
 {
 	int i;
 
+	PMAP_LOCK_INIT(pmap);
 	pmap->pm_lev1 = Lev1map;
 	pmap->pm_ptphint = NULL;
 	pmap->pm_active = 0;
@@ -1012,6 +1012,8 @@
 	vm_page_t lev1pg;
 	int i;
 
+	PMAP_LOCK_INIT(pmap);
+
 	/*
 	 * allocate object for the ptes
 	 */
@@ -1294,6 +1296,7 @@
 	mtx_lock_spin(&allpmaps_lock);
 	LIST_REMOVE(pmap, pm_list);
 	mtx_unlock_spin(&allpmaps_lock);
+	PMAP_LOCK_DESTROY(pmap);
 }
 
 /*
@@ -1618,6 +1621,7 @@
 
 	s = splvm();
 	while ((pv = TAILQ_FIRST(&m->md.pv_list)) != NULL) {
+		PMAP_LOCK(pv->pv_pmap);
 		pte = pmap_lev3pte(pv->pv_pmap, pv->pv_va);
 
 		pv->pv_pmap->pm_stats.resident_count--;
@@ -1647,6 +1651,7 @@
 		TAILQ_REMOVE(&m->md.pv_list, pv, pv_list);
 		m->md.pv_list_count--;
 		pmap_unuse_pt(pv->pv_pmap, pv->pv_va, pv->pv_ptem);
+		PMAP_UNLOCK(pv->pv_pmap);
 		free_pv_entry(pv);
 	}
 
@@ -2033,6 +2038,7 @@
 	if (pmap == NULL)
 		return;
 
+	PMAP_LOCK(pmap);
 	pte = pmap_lev3pte(pmap, va);
 
 	if (wired && !pmap_pte_w(pte))
@@ -2045,6 +2051,7 @@
 	 * invalidate TLB.
 	 */
 	pmap_pte_set_w(pte, wired);
+	PMAP_UNLOCK(pmap);
 }
 
 
@@ -2186,6 +2193,7 @@
 #endif
 
 	s = splvm();
+	PMAP_LOCK(pmap);
 	for(pv = TAILQ_FIRST(&pmap->pm_pvlist);
 		pv;
 		pv = npv) {
@@ -2232,6 +2240,7 @@
 	}
 	splx(s);
 	pmap_invalidate_all(pmap);
+	PMAP_UNLOCK(pmap);
 }
 
 /*
@@ -2273,6 +2282,7 @@
 		}
 #endif
 
+		PMAP_LOCK(pv->pv_pmap);
 		pte = pmap_lev3pte(pv->pv_pmap, pv->pv_va);
 
 		changed = 0;
@@ -2288,6 +2298,7 @@
 		}
 		if (changed)
 			pmap_invalidate_page(pv->pv_pmap, pv->pv_va);
+		PMAP_UNLOCK(pv->pv_pmap);
 	}
 	if (!setem && bit == (PG_UWE|PG_KWE))
 		vm_page_flag_clear(m, PG_WRITEABLE);
@@ -2340,6 +2351,7 @@
 	 */
 	count = 0;
 	TAILQ_FOREACH(pv, &m->md.pv_list, pv_list) {
+		PMAP_LOCK(pv->pv_pmap);
 		pte = pmap_lev3pte(pv->pv_pmap, pv->pv_va);
 		
 		if (!(*pte & PG_FOR)) {
@@ -2347,6 +2359,7 @@
 			*pte |= PG_FOR | PG_FOE;
 			pmap_invalidate_page(pv->pv_pmap, pv->pv_va);
 		}
+		PMAP_UNLOCK(pv->pv_pmap);
 	}
 
 	return count;
@@ -2416,12 +2429,14 @@
 	 * Loop over current mappings setting PG_FOW where needed.
 	 */
 	TAILQ_FOREACH(pv, &m->md.pv_list, pv_list) {
+		PMAP_LOCK(pv->pv_pmap);
 		pte = pmap_lev3pte(pv->pv_pmap, pv->pv_va);
 		
 		if (!(*pte & PG_FOW)) {
 			*pte |= PG_FOW;
 			pmap_invalidate_page(pv->pv_pmap, pv->pv_va);
 		}
+		PMAP_UNLOCK(pv->pv_pmap);
 	}
 }
 
@@ -2443,12 +2458,14 @@
 	 * Loop over current mappings setting PG_FOR and PG_FOE where needed.
 	 */
 	TAILQ_FOREACH(pv, &m->md.pv_list, pv_list) {
+		PMAP_LOCK(pv->pv_pmap);
 		pte = pmap_lev3pte(pv->pv_pmap, pv->pv_va);
 		
 		if (!(*pte & (PG_FOR | PG_FOE))) {
 			*pte |= (PG_FOR | PG_FOE);
 			pmap_invalidate_page(pv->pv_pmap, pv->pv_va);
 		}
+		PMAP_UNLOCK(pv->pv_pmap);
 	}
 }
 

==== //depot/projects/nsched/sys/alpha/include/pmap.h#6 (text+ko) ====

@@ -39,7 +39,7 @@
  *	from: hp300: @(#)pmap.h	7.2 (Berkeley) 12/16/90
  *	from: @(#)pmap.h	7.4 (Berkeley) 5/12/91
  *	from: i386 pmap.h,v 1.54 1997/11/20 19:30:35 bde Exp
- * $FreeBSD: src/sys/alpha/include/pmap.h,v 1.31 2004/06/23 08:06:52 alc Exp $
+ * $FreeBSD: src/sys/alpha/include/pmap.h,v 1.32 2004/07/05 16:59:56 alc Exp $
  */
 
 #ifndef _MACHINE_PMAP_H_
@@ -95,6 +95,8 @@
 #ifndef LOCORE
 
 #include <sys/queue.h>
+#include <sys/_lock.h>
+#include <sys/_mutex.h>
 
 typedef alpha_pt_entry_t pt_entry_t;
 
@@ -165,6 +167,7 @@
 #define	ASNGEN_MASK	((1 << ASNGEN_BITS) - 1)
 
 struct pmap {
+	struct mtx		pm_mtx;
 	pt_entry_t		*pm_lev1;	/* KVA of lev0map */
 	vm_object_t		pm_pteobj;	/* Container for pte's */
 	TAILQ_HEAD(,pv_entry)	pm_pvlist;	/* list of mappings in pmap */
@@ -183,6 +186,17 @@
 #ifdef _KERNEL
 extern struct pmap	kernel_pmap_store;
 #define kernel_pmap	(&kernel_pmap_store)
+
+#define	PMAP_LOCK(pmap)		mtx_lock(&(pmap)->pm_mtx)
+#define	PMAP_LOCK_ASSERT(pmap, type) \
+				mtx_assert(&(pmap)->pm_mtx, (type))
+#define	PMAP_LOCK_DESTROY(pmap)	mtx_destroy(&(pmap)->pm_mtx)
+#define	PMAP_LOCK_INIT(pmap)	mtx_init(&(pmap)->pm_mtx, "pmap", \
+				    NULL, MTX_DEF)
+#define	PMAP_LOCKED(pmap)	mtx_owned(&(pmap)->pm_mtx)
+#define	PMAP_MTX(pmap)		(&(pmap)->pm_mtx)
+#define	PMAP_TRYLOCK(pmap)	mtx_trylock(&(pmap)->pm_mtx)
+#define	PMAP_UNLOCK(pmap)	mtx_unlock(&(pmap)->pm_mtx)
 #endif
 
 /*

==== //depot/projects/nsched/sys/amd64/amd64/pmap.c#12 (text+ko) ====

@@ -75,7 +75,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/amd64/amd64/pmap.c,v 1.479 2004/06/23 04:37:14 alc Exp $");
+__FBSDID("$FreeBSD: src/sys/amd64/amd64/pmap.c,v 1.480 2004/07/06 02:33:11 alc Exp $");
 
 /*
  *	Manages physical address maps.
@@ -760,15 +760,13 @@
  *		with the given map/virtual_address pair.
  */
 vm_paddr_t 
-pmap_extract(pmap, va)
-	register pmap_t pmap;
-	vm_offset_t va;
+pmap_extract(pmap_t pmap, vm_offset_t va)
 {
 	vm_paddr_t rtval;
 	pt_entry_t *pte;
 	pd_entry_t pde, *pdep;
 
-	if (pmap == 0)
+	if (pmap == NULL)
 		return 0;
 	PMAP_LOCK(pmap);
 	pdep = pmap_pde(pmap, va);
@@ -781,7 +779,7 @@
 				return rtval;
 			}
 			pte = pmap_pte(pmap, va);
-			rtval = ((*pte & PG_FRAME) | (va & PAGE_MASK));
+			rtval = (*pte & PG_FRAME) | (va & PAGE_MASK);
 			PMAP_UNLOCK(pmap);
 			return rtval;
 		}

==== //depot/projects/nsched/sys/arm/arm/pmap.c#3 (text+ko) ====

@@ -144,7 +144,7 @@
  */
 /* Include header files */
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/arm/arm/pmap.c,v 1.3 2004/06/19 20:50:50 cognet Exp $");
+__FBSDID("$FreeBSD: src/sys/arm/arm/pmap.c,v 1.4 2004/07/05 23:08:27 alc Exp $");
 #include <sys/param.h>
 #include <sys/systm.h>
 #include <sys/kernel.h>
@@ -3488,7 +3488,7 @@
  *		Extract the physical page address associated
  *		with the given map/virtual_address pair.
  */
-vm_offset_t 
+vm_paddr_t
 pmap_extract(pmap_t pm, vm_offset_t va)
 {
 	struct l2_dtable *l2;

==== //depot/projects/nsched/sys/boot/common/ufsread.c#2 (text+ko) ====

@@ -23,7 +23,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/boot/common/ufsread.c,v 1.12 2003/08/25 23:30:41 obrien Exp $");
+__FBSDID("$FreeBSD: src/sys/boot/common/ufsread.c,v 1.13 2004/07/04 16:11:01 stefanf Exp $");
 
 #include <ufs/ufs/dinode.h>
 #include <ufs/ffs/fs.h>
@@ -68,7 +68,7 @@
 static int ls, dsk_meta;
 static uint32_t fs_off;
 
-static __inline__ int
+static __inline int
 fsfind(const char *name, ino_t * ino)
 {
 	char buf[DEV_BSIZE];

==== //depot/projects/nsched/sys/coda/coda_subr.c#2 (text+ko) ====

@@ -52,7 +52,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/coda/coda_subr.c,v 1.28 2003/11/05 04:30:06 kan Exp $");
+__FBSDID("$FreeBSD: src/sys/coda/coda_subr.c,v 1.29 2004/07/04 08:52:33 phk Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -308,15 +308,12 @@
 coda_checkunmounting(mp)
 	struct mount *mp;
 {
-	register struct vnode *vp, *nvp;
+	struct vnode *vp, *nvp;
 	struct cnode *cp;
 	int count = 0, bad = 0;
 
 	MNT_ILOCK(mp);
-	for (vp = TAILQ_FIRST(&mp->mnt_nvnodelist); vp; vp = nvp) {
-		nvp = TAILQ_NEXT(vp, v_nmntvnodes);
-		if (vp->v_mount != mp)
-			continue;
+	MNT_VNODE_FOREACH(vp, mp, nvp) {
 		VI_LOCK(vp);
 		if (vp->v_iflag & VI_XLOCK) {
 			VI_UNLOCK(vp);

==== //depot/projects/nsched/sys/conf/NOTES#9 (text+ko) ====

@@ -1,4 +1,4 @@
-# $FreeBSD: src/sys/conf/NOTES,v 1.1240 2004/07/02 20:21:41 jhb Exp $
+# $FreeBSD: src/sys/conf/NOTES,v 1.1241 2004/07/03 13:22:38 tjr Exp $
 #
 # NOTES -- Lines that can be cut/pasted into kernel and hints configs.
 #
@@ -843,6 +843,18 @@
 options 	NTFS_ICONV
 options 	UDF_ICONV
 
+# Experimental support for large MS-DOS filesystems.
+#
+# WARNING: This uses at least 32 bytes of kernel memory (which is not
+# reclaimed until the FS is unmounted) for each file on disk to map
+# between the 32-bit inode numbers used by VFS and the 64-bit pseudo-inode
+# numbers used internally by msdosfs. This is only safe to use in certain
+# controlled situations (e.g. read-only FS with less than 1 million files).
+# Since the mappings do not persist across unmounts (or reboots), these
+# filesystems are not suitable for exporting through NFS, or any other
+# application that requires fixed inode numbers.
+options 	MSDOSFS_LARGE
+
 
 #####################################################################
 # POSIX P1003.1B

==== //depot/projects/nsched/sys/conf/files#15 (text+ko) ====

@@ -1,4 +1,4 @@
-# $FreeBSD: src/sys/conf/files,v 1.922 2004/07/02 19:40:36 pjd Exp $
+# $FreeBSD: src/sys/conf/files,v 1.923 2004/07/03 13:22:38 tjr Exp $
 #
 # The long compile-with and dependency lines are required because of
 # limitations in config: backslash-newline doesn't work in strings, and
@@ -880,6 +880,7 @@
 fs/msdosfs/msdosfs_lookup.c	optional msdosfs
 fs/msdosfs/msdosfs_vfsops.c	optional msdosfs
 fs/msdosfs/msdosfs_vnops.c	optional msdosfs
+fs/msdosfs/msdosfs_fileno.c	optional msdosfs_large
 fs/msdosfs/msdosfs_iconv.c	optional msdosfs_iconv
 fs/ntfs/ntfs_compr.c		optional ntfs
 fs/ntfs/ntfs_ihash.c		optional ntfs

==== //depot/projects/nsched/sys/conf/options#10 (text+ko) ====

@@ -1,4 +1,4 @@
-# $FreeBSD: src/sys/conf/options,v 1.459 2004/07/02 20:21:42 jhb Exp $
+# $FreeBSD: src/sys/conf/options,v 1.460 2004/07/03 13:22:38 tjr Exp $
 #
 #        On the handling of kernel options
 #
@@ -219,6 +219,9 @@
 NETSMB			opt_netsmb.h
 NETSMBCRYPTO		opt_netsmb.h
 
+# Experimental support for large MS-DOS filesystems; SEE WARNING IN "NOTES"!
+MSDOSFS_LARGE	opt_msdosfs.h
+
 # Options used only in subr_param.c.
 HZ		opt_param.h
 MAXFILES	opt_param.h

==== //depot/projects/nsched/sys/dev/acpica/acpi_pcib_acpi.c#6 (text+ko) ====

@@ -24,7 +24,7 @@
  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  * SUCH DAMAGE.
  *
- *	$FreeBSD: src/sys/dev/acpica/acpi_pcib_acpi.c,v 1.37 2004/06/30 16:08:03 njl Exp $
+ *	$FreeBSD: src/sys/dev/acpica/acpi_pcib_acpi.c,v 1.38 2004/07/04 16:23:25 imp Exp $
  */
 #include "opt_acpi.h"
 #include <sys/param.h>
@@ -309,14 +309,16 @@
     u_long start, u_long end, u_long count, u_int flags)
 {
     /*
-     * If no memory preference is given, use upper 256MB slot most
+     * If no memory preference is given, use upper 2GB slot most
      * bioses use for their memory window.  Typically other bridges
      * before us get in the way to assert their preferences on memory.
      * Hardcoding like this sucks, so a more MD/MI way needs to be
-     * found to do it.
+     * found to do it.  This is typically only used on older laptops
+     * that don't have pci busses behind pci bridge, so assuming < 2GB
+     * is liekly OK.
      */
     if (type == SYS_RES_MEMORY && start == 0UL && end == ~0UL)
-	start = 0xf0000000;
+	start = 0x80000000;
     return (bus_generic_alloc_resource(dev, child, type, rid, start, end,
 	count, flags));
 }

==== //depot/projects/nsched/sys/dev/fdc/fdc.c#4 (text+ko) ====

@@ -49,7 +49,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/dev/fdc/fdc.c,v 1.273 2004/06/16 09:46:43 phk Exp $");
+__FBSDID("$FreeBSD: src/sys/dev/fdc/fdc.c,v 1.275 2004/07/05 20:56:06 phk Exp $");
 
 #include "opt_fdc.h"
 #include "card.h"
@@ -132,6 +132,7 @@
 {
 	int	fdcu;		/* our unit number */
 	int	dmachan;
+	int	dmacnt;
 	int	flags;
 #define FDC_ATTACHED	0x01
 #define FDC_STAT_VALID	0x08
@@ -770,7 +771,8 @@
 	}
 
 	fdc->res_irq = bus_alloc_resource_any(dev, SYS_RES_IRQ,
-					      &fdc->rid_irq, RF_ACTIVE);
+					      &fdc->rid_irq,
+					      RF_ACTIVE | RF_SHAREABLE);
 	if (fdc->res_irq == 0) {
 		device_printf(dev, "cannot reserve interrupt line\n");
 		return ENXIO;
@@ -778,13 +780,12 @@
 
 	if ((fdc->flags & FDC_NODMA) == 0) {
 		fdc->res_drq = bus_alloc_resource_any(dev, SYS_RES_DRQ,
-						      &fdc->rid_drq,
-						      RF_ACTIVE);
+		    &fdc->rid_drq, RF_ACTIVE | RF_SHAREABLE);
 		if (fdc->res_drq == 0) {
 			device_printf(dev, "cannot reserve DMA request line\n");
-			return ENXIO;
-		}
-		fdc->dmachan = rman_get_start(fdc->res_drq);
+			fdc->flags |= FDC_NODMA;
+		} else
+			fdc->dmachan = rman_get_start(fdc->res_drq);
 	}
 
 	return 0;
@@ -964,9 +965,6 @@
 	/* reset controller, turn motor off */
 	fdout_wr(fdc, 0);
 
-	if ((fdc->flags & FDC_NODMA) == 0)
-		isa_dma_release(fdc->dmachan);
-
 	if ((fdc->flags & FDC_ATTACHED) == 0) {
 		device_printf(dev, "already unloaded\n");
 		return (0);
@@ -1030,15 +1028,6 @@
 	fdc->fdcu = device_get_unit(dev);
 	fdc->flags |= FDC_ATTACHED | FDC_NEEDS_RESET;
 
-	if ((fdc->flags & FDC_NODMA) == 0) {
-		/*
-		 * Acquire the DMA channel forever, the driver will do
-		 * the rest
-		 * XXX should integrate with rman
-		 */
-		isa_dma_acquire(fdc->dmachan);
-		isa_dmainit(fdc->dmachan, MAX_SEC_SIZE);
-	}
 	fdc->state = DEVIDLE;
 
 	/* reset controller, turn motor off, clear fdout mirror reg */
@@ -1574,6 +1563,14 @@
 			return (rv);
 	}
 	fd->flags |= FD_OPEN;
+
+	if ((fdc->flags & FDC_NODMA) == 0) {
+		if (fdc->dmacnt++ == 0) {
+			isa_dma_acquire(fdc->dmachan);
+			isa_dmainit(fdc->dmachan, MAX_SEC_SIZE);
+		}
+	}
+
 	/*
 	 * Clearing the DMA overrun counter at open time is a bit messy.
 	 * Since we're only managing one counter per controller, opening
@@ -1594,11 +1591,17 @@
 fdclose(struct cdev *dev, int flags, int mode, struct thread *td)
 {
 	struct fd_data *fd;
+ 	fdc_p	fdc;
 
 	fd = dev->si_drv1;
+	fdc = fd->fdc;
 	fd->flags &= ~(FD_OPEN | FD_NONBLOCK);
 	fd->options &= ~(FDOPT_NORETRY | FDOPT_NOERRLOG | FDOPT_NOERROR);
 
+	if ((fdc->flags & FDC_NODMA) == 0)
+		if (--fdc->dmacnt == 0)
+			isa_dma_release(fdc->dmachan);
+
 	return (0);
 }
 

==== //depot/projects/nsched/sys/dev/hifn/hifn7751.c#3 (text+ko) ====

@@ -41,7 +41,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/dev/hifn/hifn7751.c,v 1.27 2004/05/30 20:08:33 phk Exp $");
+__FBSDID("$FreeBSD: src/sys/dev/hifn/hifn7751.c,v 1.28 2004/07/04 16:11:01 stefanf Exp $");
 
 /*
  * Driver for various Hifn encryption processors.
@@ -151,7 +151,7 @@
 static	void hifn_write_reg_0(struct hifn_softc *, bus_size_t, u_int32_t);
 static	void hifn_write_reg_1(struct hifn_softc *, bus_size_t, u_int32_t);
 
-static __inline__ u_int32_t
+static __inline u_int32_t
 READ_REG_0(struct hifn_softc *sc, bus_size_t reg)
 {
     u_int32_t v = bus_space_read_4(sc->sc_st0, sc->sc_sh0, reg);
@@ -160,7 +160,7 @@
 }
 #define	WRITE_REG_0(sc, reg, val)	hifn_write_reg_0(sc, reg, val)
 
-static __inline__ u_int32_t
+static __inline u_int32_t
 READ_REG_1(struct hifn_softc *sc, bus_size_t reg)
 {
     u_int32_t v = bus_space_read_4(sc->sc_st1, sc->sc_sh1, reg);

==== //depot/projects/nsched/sys/dev/nmdm/nmdm.c#7 (text+ko) ====

@@ -29,7 +29,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/dev/nmdm/nmdm.c,v 1.28 2004/06/17 17:16:45 phk Exp $");
+__FBSDID("$FreeBSD: src/sys/dev/nmdm/nmdm.c,v 1.29 2004/07/04 16:27:58 phk Exp $");
 
 /*
  * Pseudo-nulmodem driver
@@ -48,6 +48,7 @@
 #include <sys/poll.h>
 #include <sys/kernel.h>
 #include <sys/module.h>
+#include <sys/serial.h>
 #include <sys/vnode.h>
 #include <sys/signalvar.h>
 #include <sys/malloc.h>
@@ -58,6 +59,7 @@
 static void 	nmdmstart(struct tty *tp);
 static void 	nmdmstop(struct tty *tp, int rw);
 static void 	nmdminit(struct cdev *dev);
+static t_modem_t	nmdmmodem;
 
 static d_open_t		nmdmopen;
 static d_close_t	nmdmclose;
@@ -76,9 +78,9 @@
 #define BFLAG		CLONE_FLAG0
 
 struct softpart {
-	struct tty	*nm_tty;
-	struct cdev *dev;
-	int	dcd;
+	struct tty		*nm_tty;
+	struct cdev 		*dev;
+	int			nm_dcd;
 	struct task		pt_task;
 	struct softpart		*other;
 };
@@ -151,14 +153,14 @@
 	otp = sp->other->nm_tty;
 	KASSERT(otp != NULL, ("NULL otp in nmdmstart"));
 	KASSERT(otp != tp, ("NULL otp == tp nmdmstart"));
-	if (sp->other->dcd) {
+	if (sp->other->nm_dcd) {
 		if (!(tp->t_state & TS_ISOPEN)) {
-			sp->other->dcd = 0;
+			sp->other->nm_dcd = 0;
 			(void)ttyld_modem(otp, 0);
 		}
 	} else {
 		if (tp->t_state & TS_ISOPEN) {
-			sp->other->dcd = 1;
+			sp->other->nm_dcd = 1;
 			(void)ttyld_modem(otp, 1);
 		}
 	}
@@ -200,6 +202,7 @@
 	pt->part1.nm_tty = ttymalloc(pt->part1.nm_tty);
 	pt->part1.nm_tty->t_oproc = nmdmstart;
 	pt->part1.nm_tty->t_stop = nmdmstop;
+	pt->part1.nm_tty->t_modem = nmdmmodem;
 	pt->part1.nm_tty->t_dev = dev1;
 	pt->part1.nm_tty->t_sc = &pt->part1;
 	TASK_INIT(&pt->part1.pt_task, 0, nmdm_task_tty, pt->part1.nm_tty);
@@ -207,6 +210,7 @@
 	pt->part2.nm_tty = ttymalloc(pt->part2.nm_tty);
 	pt->part2.nm_tty->t_oproc = nmdmstart;
 	pt->part2.nm_tty->t_stop = nmdmstop;
+	pt->part2.nm_tty->t_modem = nmdmmodem;
 	pt->part2.nm_tty->t_dev = dev2;
 	pt->part2.nm_tty->t_sc = &pt->part2;
 	TASK_INIT(&pt->part2.pt_task, 0, nmdm_task_tty, pt->part2.nm_tty);
@@ -260,6 +264,33 @@
 }
 
 static int
+nmdmmodem(struct tty *tp, int sigon, int sigoff)
+{
+	struct softpart *sp;
+	int i;
+
+	sp = tp->t_sc;
+	if (sigon || sigoff) {
+		if (sigon & SER_DTR) {
+			sp->other->nm_dcd = 1;
+			ttyld_modem(sp->other->nm_tty, sp->other->nm_dcd);
+		}
+		if (sigoff & SER_DTR) {
+			sp->other->nm_dcd = 0;
+			ttyld_modem(sp->other->nm_tty, sp->other->nm_dcd);
+		}
+		return (0);
+	} else {
+		i = 0;
+		if (sp->nm_dcd)
+			i |= SER_DCD;
+		if (sp->other->nm_dcd)
+			i |= SER_DTR;
+		return (i);
+	}
+}
+
+static int
 nmdmclose(struct cdev *dev, int flag, int mode, struct thread *td)
 {
 

==== //depot/projects/nsched/sys/dev/pcf/pcfvar.h#2 (text+ko) ====

@@ -24,7 +24,7 @@
  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  * SUCH DAMAGE.
  *
- * $FreeBSD: src/sys/dev/pcf/pcfvar.h,v 1.1 2004/05/25 07:42:45 joerg Exp $
+ * $FreeBSD: src/sys/dev/pcf/pcfvar.h,v 1.2 2004/07/04 16:11:01 stefanf Exp $
  */
 
 #define IO_PCFSIZE	2
@@ -86,7 +86,7 @@
 /*
  * Specific register access to PCF8584
  */
-static __inline__ void
+static __inline void
 pcf_set_S0(struct pcf_softc *sc, int data)
 {
 	bus_space_write_1(sc->res_ioport->r_bustag,
@@ -95,7 +95,7 @@
 	pcf_nops();
 }
 
-static __inline__ void
+static __inline void
 pcf_set_S1(struct pcf_softc *sc, int data)
 {
 	bus_space_write_1(sc->res_ioport->r_bustag,
@@ -104,7 +104,7 @@
 	pcf_nops();
 }
 
-static __inline__ char
+static __inline char
 pcf_get_S0(struct pcf_softc *sc)
 {
 	char data;
@@ -116,7 +116,7 @@
 	return (data);
 }
 
-static __inline__ char
+static __inline char
 pcf_get_S1(struct pcf_softc *sc)
 {
 	char data;

==== //depot/projects/nsched/sys/dev/re/if_re.c#6 (text+ko) ====

@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/dev/re/if_re.c,v 1.26 2004/06/28 20:09:02 imp Exp $");
+__FBSDID("$FreeBSD: src/sys/dev/re/if_re.c,v 1.28 2004/07/06 02:48:29 bms Exp $");
 
 /*
  * RealTek 8139C+/8169/8169S/8110S PCI NIC driver
@@ -79,11 +79,11 @@
  *
  *	o Jumbo frames
  *
- * 	o GMII and TBI ports/registers for interfacing with copper
+ *	o GMII and TBI ports/registers for interfacing with copper
  *	  or fiber PHYs
  *
- *      o RX and TX DMA rings can have up to 1024 descriptors
- *        (the 8139C+ allows a maximum of 64)
+ *	o RX and TX DMA rings can have up to 1024 descriptors
+ *	  (the 8139C+ allows a maximum of 64)
  *
  *	o Slight differences in register layout from the 8139C+
  *
@@ -98,7 +98,7 @@
  * programming API as the older 8169, but also have some vendor-specific
  * registers for the on-board PHY. The 8110S is a LAN-on-motherboard
  * part designed to be pin-compatible with the RealTek 8100 10/100 chip.
- * 
+ *
  * This driver takes advantage of the RX and TX checksum offload and
  * VLAN tag insertion/extraction features. It also implements TX
  * interrupt moderation using the timer interrupt registers, which
@@ -307,8 +307,6 @@
 		EE_CLR(RL_EE_CLK);
 		DELAY(100);
 	}
-
-	return;
 }
 
 /*
@@ -349,8 +347,6 @@
 	CSR_WRITE_1(sc, RL_EECMD, RL_EEMODE_OFF);
 
 	*dest = word;
-
-	return;
 }
 
 /*
@@ -375,8 +371,6 @@
 		else
 			*ptr = word;
 	}
-
-	return;
 }
 
 static int
@@ -389,7 +383,7 @@
 	int			i;
 
 	if (phy != 1)
-		return(0);
+		return (0);
 
 	sc = device_get_softc(dev);
 
@@ -397,7 +391,7 @@
 
 	if (reg == RL_GMEDIASTAT) {
 		rval = CSR_READ_1(sc, RL_GMEDIASTAT);
-		return(rval);
+		return (rval);
 	}
 
 	CSR_WRITE_4(sc, RL_PHYAR, reg << 16);
@@ -469,9 +463,9 @@
 	/* Pretend the internal PHY is only at address 0 */
 	if (phy) {
 		RL_UNLOCK(sc);
-		return(0);
+		return (0);
 	}
-	switch(reg) {
+	switch (reg) {
 	case MII_BMCR:
 		re8139_reg = RL_BMCR;
 		break;
@@ -490,7 +484,7 @@
 	case MII_PHYIDR1:
 	case MII_PHYIDR2:
 		RL_UNLOCK(sc);
-		return(0);
+		return (0);
 	/*
 	 * Allow the rlphy driver to read the media status
 	 * register. If we have a link partner which does not
@@ -500,15 +494,15 @@
 	case RL_MEDIASTAT:
 		rval = CSR_READ_1(sc, RL_MEDIASTAT);
 		RL_UNLOCK(sc);
-		return(rval);
+		return (rval);
 	default:
 		printf("re%d: bad phy register\n", sc->rl_unit);
 		RL_UNLOCK(sc);
-		return(0);
+		return (0);
 	}
 	rval = CSR_READ_2(sc, re8139_reg);
 	RL_UNLOCK(sc);
-	return(rval);
+	return (rval);
 }
 
 static int
@@ -532,9 +526,9 @@
 	/* Pretend the internal PHY is only at address 0 */
 	if (phy) {
 		RL_UNLOCK(sc);
-		return(0);
+		return (0);
 	}
-	switch(reg) {
+	switch (reg) {
 	case MII_BMCR:
 		re8139_reg = RL_BMCR;
 		break;
@@ -553,23 +547,23 @@
 	case MII_PHYIDR1:
 	case MII_PHYIDR2:
 		RL_UNLOCK(sc);
-		return(0);
+		return (0);
 		break;
 	default:
 		printf("re%d: bad phy register\n", sc->rl_unit);
 		RL_UNLOCK(sc);
-		return(0);
+		return (0);
 	}
 	CSR_WRITE_2(sc, re8139_reg, data);
 	RL_UNLOCK(sc);
-	return(0);
+	return (0);
 }
 
 static void
 re_miibus_statchg(dev)
 	device_t		dev;
 {
-	return;
+
 }
 
 /*
@@ -623,8 +617,6 @@
 	CSR_WRITE_4(sc, RL_RXCFG, rxfilt);
 	CSR_WRITE_4(sc, RL_MAR0, hashes[0]);
 	CSR_WRITE_4(sc, RL_MAR4, hashes[1]);
-
-	return;
 }
 
 static void
@@ -644,8 +636,6 @@
 		printf("re%d: reset never completed!\n", sc->rl_unit);
 
 	CSR_WRITE_1(sc, 0x82, 1);
-

>>> TRUNCATED FOR MAIL (1000 lines) <<<



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200407060706.i66764tE009904>