Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 25 Apr 2006 19:00:38 GMT
From:      John Baldwin <jhb@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 96084 for review
Message-ID:  <200604251900.k3PJ0c44095931@repoman.freebsd.org>

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

Change 96084 by jhb@jhb_slimer on 2006/04/25 18:59:59

	IFC @96080.

Affected files ...

.. //depot/projects/smpng/sys/alpha/conf/GENERIC#55 integrate
.. //depot/projects/smpng/sys/alpha/isa/isa.c#16 integrate
.. //depot/projects/smpng/sys/alpha/pci/apecs_pci.c#5 integrate
.. //depot/projects/smpng/sys/alpha/pci/lca_pci.c#7 integrate
.. //depot/projects/smpng/sys/alpha/pci/pcibus.c#9 integrate
.. //depot/projects/smpng/sys/amd64/amd64/dump_machdep.c#4 integrate
.. //depot/projects/smpng/sys/amd64/amd64/fpu.c#9 integrate
.. //depot/projects/smpng/sys/amd64/amd64/identcpu.c#18 integrate
.. //depot/projects/smpng/sys/amd64/amd64/minidump_machdep.c#1 branch
.. //depot/projects/smpng/sys/amd64/amd64/mp_machdep.c#36 integrate
.. //depot/projects/smpng/sys/amd64/amd64/nexus.c#18 integrate
.. //depot/projects/smpng/sys/amd64/amd64/pmap.c#55 integrate
.. //depot/projects/smpng/sys/amd64/amd64/uma_machdep.c#2 integrate
.. //depot/projects/smpng/sys/amd64/conf/GENERIC#43 integrate
.. //depot/projects/smpng/sys/amd64/include/md_var.h#12 integrate
.. //depot/projects/smpng/sys/amd64/include/minidump.h#1 branch
.. //depot/projects/smpng/sys/arm/arm/nexus.c#7 integrate
.. //depot/projects/smpng/sys/arm/arm/pmap.c#27 integrate
.. //depot/projects/smpng/sys/arm/at91/at91.c#4 integrate
.. //depot/projects/smpng/sys/arm/sa11x0/sa11x0.c#6 integrate
.. //depot/projects/smpng/sys/arm/xscale/i80321/i80321_pci.c#8 integrate
.. //depot/projects/smpng/sys/arm/xscale/i80321/iq80321.c#9 integrate
.. //depot/projects/smpng/sys/arm/xscale/i80321/obio.c#4 integrate
.. //depot/projects/smpng/sys/boot/arm/at91/Makefile#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/Makefile.inc#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/boot0/Makefile#2 integrate
.. //depot/projects/smpng/sys/boot/arm/at91/boot0/at91rm9200_lowlevel.c#2 delete
.. //depot/projects/smpng/sys/boot/arm/at91/boot0/at91rm9200_lowlevel.h#2 delete
.. //depot/projects/smpng/sys/boot/arm/at91/boot0/lib.c#2 delete
.. //depot/projects/smpng/sys/boot/arm/at91/boot0/lib.h#2 delete
.. //depot/projects/smpng/sys/boot/arm/at91/boot0/main.c#2 integrate
.. //depot/projects/smpng/sys/boot/arm/at91/boot0/xmodem.c#2 delete
.. //depot/projects/smpng/sys/boot/arm/at91/boot0/xmodem.h#2 delete
.. //depot/projects/smpng/sys/boot/arm/at91/boot0iic/Makefile#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/boot0iic/doit.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/boot0iic/main.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/boot0spi/Makefile#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/boot0spi/doit.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/boot0spi/main.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/bootiic/Makefile#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/bootiic/README#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/bootiic/arm_init.S#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/bootiic/main.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/bootspi/Makefile#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/bootspi/README#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/bootspi/arm_init.s#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/bootspi/main.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/inc/AT91RM9200.h#3 delete
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/Makefile#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/at91rm9200.h#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/at91rm9200_lowlevel.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/at91rm9200_lowlevel.h#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/eeprom.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/eeprom.h#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/emac.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/emac.h#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/env_vars.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/env_vars.h#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/getc.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/lib.h#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/loader_prompt.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/loader_prompt.h#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/p_string.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/p_string.h#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/printf.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/putchar.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/tag_list.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/tag_list.h#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/libat91/xmodem.c#1 branch
.. //depot/projects/smpng/sys/boot/arm/at91/linker.cfg#1 branch
.. //depot/projects/smpng/sys/cam/cam.c#7 integrate
.. //depot/projects/smpng/sys/cam/scsi/scsi_da.c#67 integrate
.. //depot/projects/smpng/sys/conf/NOTES#117 integrate
.. //depot/projects/smpng/sys/conf/files#173 integrate
.. //depot/projects/smpng/sys/conf/files.alpha#39 integrate
.. //depot/projects/smpng/sys/conf/files.amd64#41 integrate
.. //depot/projects/smpng/sys/conf/files.i386#95 integrate
.. //depot/projects/smpng/sys/conf/files.ia64#54 integrate
.. //depot/projects/smpng/sys/conf/files.pc98#81 integrate
.. //depot/projects/smpng/sys/conf/files.powerpc#28 integrate
.. //depot/projects/smpng/sys/conf/options#118 integrate
.. //depot/projects/smpng/sys/conf/options.alpha#14 integrate
.. //depot/projects/smpng/sys/conf/options.amd64#18 integrate
.. //depot/projects/smpng/sys/conf/options.i386#56 integrate
.. //depot/projects/smpng/sys/conf/options.ia64#20 integrate
.. //depot/projects/smpng/sys/conf/options.pc98#55 integrate
.. //depot/projects/smpng/sys/crypto/via/padlock.c#3 integrate
.. //depot/projects/smpng/sys/ddb/db_command.c#28 integrate
.. //depot/projects/smpng/sys/dev/acpica/acpi.c#92 integrate
.. //depot/projects/smpng/sys/dev/acpica/acpi_powerres.c#22 integrate
.. //depot/projects/smpng/sys/dev/bge/if_bge.c#74 integrate
.. //depot/projects/smpng/sys/dev/ciss/ciss.c#45 integrate
.. //depot/projects/smpng/sys/dev/isp/isp.c#39 integrate
.. //depot/projects/smpng/sys/dev/isp/isp_freebsd.c#39 integrate
.. //depot/projects/smpng/sys/dev/isp/isp_freebsd.h#29 integrate
.. //depot/projects/smpng/sys/dev/isp/isp_ioctl.h#15 integrate
.. //depot/projects/smpng/sys/dev/isp/isp_library.c#2 integrate
.. //depot/projects/smpng/sys/dev/isp/isp_pci.c#34 integrate
.. //depot/projects/smpng/sys/dev/isp/isp_sbus.c#13 integrate
.. //depot/projects/smpng/sys/dev/isp/isp_target.c#17 integrate
.. //depot/projects/smpng/sys/dev/isp/isp_target.h#12 integrate
.. //depot/projects/smpng/sys/dev/isp/isp_tpublic.h#8 integrate
.. //depot/projects/smpng/sys/dev/isp/ispmbox.h#20 integrate
.. //depot/projects/smpng/sys/dev/ispfw/asm_2300.h#9 integrate
.. //depot/projects/smpng/sys/dev/mpt/mpt.c#15 integrate
.. //depot/projects/smpng/sys/dev/mpt/mpt_cam.c#8 integrate
.. //depot/projects/smpng/sys/dev/pci/pci_pci.c#28 integrate
.. //depot/projects/smpng/sys/dev/ppc/ppc.c#12 integrate
.. //depot/projects/smpng/sys/dev/ppc/ppc_acpi.c#1 branch
.. //depot/projects/smpng/sys/dev/ppc/ppc_isa.c#1 branch
.. //depot/projects/smpng/sys/dev/ppc/ppc_pci.c#1 branch
.. //depot/projects/smpng/sys/dev/ppc/ppc_puc.c#3 integrate
.. //depot/projects/smpng/sys/dev/ppc/ppcreg.h#2 integrate
.. //depot/projects/smpng/sys/dev/ppc/ppcvar.h#4 integrate
.. //depot/projects/smpng/sys/dev/sab/sab.c#29 delete
.. //depot/projects/smpng/sys/dev/sab/sab82532reg.h#3 delete
.. //depot/projects/smpng/sys/dev/sound/pci/via8233.c#20 integrate
.. //depot/projects/smpng/sys/dev/uart/uart_dev_ns8250.c#12 integrate
.. //depot/projects/smpng/sys/geom/eli/g_eli.c#11 integrate
.. //depot/projects/smpng/sys/geom/eli/g_eli_crypto.c#3 integrate
.. //depot/projects/smpng/sys/i386/conf/GENERIC#73 integrate
.. //depot/projects/smpng/sys/i386/i386/dump_machdep.c#8 integrate
.. //depot/projects/smpng/sys/i386/i386/identcpu.c#44 integrate
.. //depot/projects/smpng/sys/i386/i386/minidump_machdep.c#1 branch
.. //depot/projects/smpng/sys/i386/i386/mp_machdep.c#100 integrate
.. //depot/projects/smpng/sys/i386/i386/nexus.c#19 integrate
.. //depot/projects/smpng/sys/i386/include/md_var.h#31 integrate
.. //depot/projects/smpng/sys/i386/include/minidump.h#1 branch
.. //depot/projects/smpng/sys/i386/isa/npx.c#57 integrate
.. //depot/projects/smpng/sys/ia64/ia64/nexus.c#12 integrate
.. //depot/projects/smpng/sys/kern/kern_mbuf.c#18 integrate
.. //depot/projects/smpng/sys/kern/kern_rwlock.c#6 integrate
.. //depot/projects/smpng/sys/kern/kern_sig.c#124 integrate
.. //depot/projects/smpng/sys/kern/serdev_if.m#2 integrate
.. //depot/projects/smpng/sys/kern/subr_bus.c#59 integrate
.. //depot/projects/smpng/sys/kern/subr_rman.c#26 integrate
.. //depot/projects/smpng/sys/kern/subr_sleepqueue.c#27 integrate
.. //depot/projects/smpng/sys/kern/subr_turnstile.c#27 integrate
.. //depot/projects/smpng/sys/kern/uipc_domain.c#16 integrate
.. //depot/projects/smpng/sys/kern/uipc_socket.c#83 integrate
.. //depot/projects/smpng/sys/kern/uipc_socket2.c#51 integrate
.. //depot/projects/smpng/sys/kern/uipc_syscalls.c#75 integrate
.. //depot/projects/smpng/sys/kern/uipc_usrreq.c#57 integrate
.. //depot/projects/smpng/sys/netinet/in_pcb.c#61 integrate
.. //depot/projects/smpng/sys/netinet/in_pcb.h#41 integrate
.. //depot/projects/smpng/sys/netinet/ip_divert.c#47 integrate
.. //depot/projects/smpng/sys/netinet/ip_input.c#77 integrate
.. //depot/projects/smpng/sys/netinet/raw_ip.c#56 integrate
.. //depot/projects/smpng/sys/netinet/tcp_input.c#85 integrate
.. //depot/projects/smpng/sys/netinet/tcp_subr.c#78 integrate
.. //depot/projects/smpng/sys/netinet/tcp_usrreq.c#48 integrate
.. //depot/projects/smpng/sys/netinet/udp_usrreq.c#66 integrate
.. //depot/projects/smpng/sys/netinet6/frag6.c#10 integrate
.. //depot/projects/smpng/sys/netinet6/in6_ifattach.c#17 integrate
.. //depot/projects/smpng/sys/netinet6/in6_pcb.c#42 integrate
.. //depot/projects/smpng/sys/netinet6/in6_pcb.h#13 integrate
.. //depot/projects/smpng/sys/netinet6/in6_src.c#24 integrate
.. //depot/projects/smpng/sys/netnatm/natm.c#27 integrate
.. //depot/projects/smpng/sys/netnatm/natm_pcb.c#8 integrate
.. //depot/projects/smpng/sys/nfsserver/nfsrvcache.h#5 integrate
.. //depot/projects/smpng/sys/pc98/cbus/ppc.c#4 delete
.. //depot/projects/smpng/sys/pc98/cbus/ppcreg.h#2 delete
.. //depot/projects/smpng/sys/pc98/include/minidump.h#1 branch
.. //depot/projects/smpng/sys/pc98/pc98/machdep.c#12 integrate
.. //depot/projects/smpng/sys/powerpc/powermac/grackle.c#8 integrate
.. //depot/projects/smpng/sys/powerpc/powermac/hrowpic.c#9 integrate
.. //depot/projects/smpng/sys/powerpc/powermac/macio.c#12 integrate
.. //depot/projects/smpng/sys/powerpc/powermac/uninorth.c#11 integrate
.. //depot/projects/smpng/sys/powerpc/powerpc/openpic.c#9 integrate
.. //depot/projects/smpng/sys/powerpc/psim/iobus.c#8 integrate
.. //depot/projects/smpng/sys/security/mac_bsdextended/mac_bsdextended.c#19 integrate
.. //depot/projects/smpng/sys/security/mac_bsdextended/mac_bsdextended.h#5 integrate
.. //depot/projects/smpng/sys/sparc64/conf/GENERIC#66 integrate
.. //depot/projects/smpng/sys/sparc64/conf/NOTES#21 integrate
.. //depot/projects/smpng/sys/sparc64/ebus/ebus.c#23 integrate
.. //depot/projects/smpng/sys/sparc64/pci/psycho.c#38 integrate
.. //depot/projects/smpng/sys/sparc64/sbus/sbus.c#24 integrate
.. //depot/projects/smpng/sys/sparc64/sparc64/nexus.c#15 integrate
.. //depot/projects/smpng/sys/sys/bus.h#26 integrate
.. //depot/projects/smpng/sys/sys/eventhandler.h#22 integrate
.. //depot/projects/smpng/sys/sys/param.h#99 integrate
.. //depot/projects/smpng/sys/sys/rwlock.h#3 integrate
.. //depot/projects/smpng/sys/ufs/ffs/ffs_vfsops.c#84 integrate
.. //depot/projects/smpng/sys/vm/vm_mmap.c#58 integrate
.. //depot/projects/smpng/sys/vm/vm_page.c#74 integrate
.. //depot/projects/smpng/sys/vm/vm_pageq.c#18 integrate

Differences ...

==== //depot/projects/smpng/sys/alpha/conf/GENERIC#55 (text+ko) ====

@@ -18,7 +18,7 @@
 #
 # For hardware specific information check HARDWARE.TXT
 #
-# $FreeBSD: src/sys/alpha/conf/GENERIC,v 1.192 2006/01/10 09:19:07 phk Exp $
+# $FreeBSD: src/sys/alpha/conf/GENERIC,v 1.193 2006/04/24 08:44:33 delphij Exp $
 
 cpu		EV4
 cpu		EV5
@@ -70,8 +70,6 @@
 options 	SYSVMSG			# SYSV-style message queues
 options 	SYSVSEM			# SYSV-style semaphores
 options 	_KPOSIX_PRIORITY_SCHEDULING # POSIX P1003_1B real-time extensions
-options 	AHC_REG_PRETTY_PRINT	# Print register bitfields in debug
-					# output.  Adds ~128k to driver.
 options 	ADAPTIVE_GIANT		# Giant mutex is adaptive.
 
 # Debugging for use in -current
@@ -106,6 +104,8 @@
 
 # SCSI Controllers
 device		ahc		# AHA2940 and onboard AIC7xxx devices
+options 	AHC_REG_PRETTY_PRINT	# Print register bitfields in debug
+					# output.  Adds ~128k to driver.
 device		isp		# Qlogic family
 device		ispfw		# Firmware module for Qlogic host adapters
 device		mpt		# LSI-Logic MPT-Fusion

==== //depot/projects/smpng/sys/alpha/isa/isa.c#16 (text+ko) ====

@@ -25,7 +25,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/alpha/isa/isa.c,v 1.38 2005/10/25 19:48:45 jhb Exp $");
+__FBSDID("$FreeBSD: src/sys/alpha/isa/isa.c,v 1.39 2006/04/20 04:16:02 imp Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -231,6 +231,7 @@
 	    res = rman_reserve_resource(&isa_drq_rman, start, start, 1,
 					0, child);
 	    
+	rman_set_rid(res, *rid);
 	if (res && !passthrough) {
 		rle = resource_list_find(rl, type, *rid);
 		rle->start = rman_get_start(res);

==== //depot/projects/smpng/sys/alpha/pci/apecs_pci.c#5 (text+ko) ====

@@ -25,7 +25,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/alpha/pci/apecs_pci.c,v 1.15 2003/08/22 07:20:27 imp Exp $");
+__FBSDID("$FreeBSD: src/sys/alpha/pci/apecs_pci.c,v 1.16 2006/04/20 04:16:02 imp Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -79,12 +79,17 @@
 apecs_pcib_alloc_resource(device_t bus, device_t child, int type, int *rid,
 			  u_long start, u_long end, u_long count, u_int flags)
 {
+	struct resource *rv = NULL;
+
 	if ((hwrpb->rpb_type == ST_DEC_2100_A50) &&
 	    (type == SYS_RES_IRQ))
-		return isa_alloc_intr(bus, child, start);
+		rv = isa_alloc_intr(bus, child, start);
 	else
-		return alpha_pci_alloc_resource(bus, child, type, rid,
-					  start, end, count, flags);
+		rv = alpha_pci_alloc_resource(bus, child, type, rid,
+		    start, end, count, flags);
+	if (rv != NULL)
+		rman_set_rid(rv, *rid);
+	return (rv);
 }
 
 static int

==== //depot/projects/smpng/sys/alpha/pci/lca_pci.c#7 (text+ko) ====

@@ -25,7 +25,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/alpha/pci/lca_pci.c,v 1.17 2003/08/22 07:20:27 imp Exp $");
+__FBSDID("$FreeBSD: src/sys/alpha/pci/lca_pci.c,v 1.18 2006/04/20 04:16:02 imp Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -78,11 +78,16 @@
 lca_pcib_alloc_resource(device_t bus, device_t child, int type, int *rid,
 			u_long start, u_long end, u_long count, u_int flags)
 {
+	struct resource *rv = NULL;
+
 	if (type == SYS_RES_IRQ)
-		return isa_alloc_intr(bus, child, start);
+		rv = isa_alloc_intr(bus, child, start);
 	else
-		return alpha_pci_alloc_resource(bus, child, type, rid,
-					  start, end, count, flags);
+		rv = alpha_pci_alloc_resource(bus, child, type, rid,
+		    start, end, count, flags);
+	if (rv != NULL)
+		rman_set_rid(rv, *rid);
+	return (rv);
 }
 
 static int

==== //depot/projects/smpng/sys/alpha/pci/pcibus.c#9 (text+ko) ====

@@ -25,7 +25,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/alpha/pci/pcibus.c,v 1.37 2005/09/25 20:12:29 phk Exp $");
+__FBSDID("$FreeBSD: src/sys/alpha/pci/pcibus.c,v 1.39 2006/04/22 19:04:21 marcel Exp $");
 
 #include "opt_isa.h"
 
@@ -96,7 +96,7 @@
 alpha_platform_alloc_ide_intr(int chan)
 {
 	int irqs[2] = { 14, 15 };
-	return isa_alloc_intr(0, 0, irqs[chan]);
+	return (isa_alloc_intr(0, 0, irqs[chan]));
 }
 
 int
@@ -230,9 +230,11 @@
 #ifdef DEV_ISA
 		if((start >= ISA_IRQ_OFFSET) &&
 		   (end < ISA_IRQ_OFFSET + ISA_IRQ_LEN)) {
-		  	return isa_alloc_intrs(bus, child,
-					       start - ISA_IRQ_OFFSET,
-					       end - ISA_IRQ_OFFSET);
+		  	rv = isa_alloc_intrs(bus, child,
+			    start - ISA_IRQ_OFFSET, end - ISA_IRQ_OFFSET);
+			if (rv != NULL)
+				rman_set_rid(rv, *rid);
+			return (rv);
 		}
 		else
 #endif
@@ -252,6 +254,7 @@
 	if (rv == 0)
 		return 0;
 
+	rman_set_rid(rv, *rid);
 	rstart = rman_get_start(rv);
 	rman_set_bustag(rv, ALPHAPCI_GET_BUSTAG(bus, type));
 	rman_set_bushandle(rv, rstart);

==== //depot/projects/smpng/sys/amd64/amd64/dump_machdep.c#4 (text+ko) ====

@@ -25,12 +25,13 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/amd64/amd64/dump_machdep.c,v 1.11 2005/07/02 19:57:30 marcel Exp $");
+__FBSDID("$FreeBSD: src/sys/amd64/amd64/dump_machdep.c,v 1.12 2006/04/21 04:24:50 peter Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
 #include <sys/conf.h>
 #include <sys/cons.h>
+#include <sys/sysctl.h>
 #include <sys/kernel.h>
 #include <sys/kerneldump.h>
 #include <vm/vm.h>
@@ -40,6 +41,11 @@
 
 CTASSERT(sizeof(struct kerneldumpheader) == 512);
 
+int do_minidump = 1;
+TUNABLE_INT("debug.minidump", &do_minidump);
+SYSCTL_INT(_debug, OID_AUTO, minidump, CTLFLAG_RW, &do_minidump, 0,
+    "Enable mini crash dumps");
+
 /*
  * Don't touch the first SIZEOF_METADATA bytes on the dump device. This
  * is to protect us from metadata and to protect metadata from us.
@@ -272,6 +278,10 @@
 	size_t hdrsz;
 	int error;
 
+	if (do_minidump) {
+		minidumpsys(di);
+		return;
+	}
 	bzero(&ehdr, sizeof(ehdr));
 	ehdr.e_ident[EI_MAG0] = ELFMAG0;
 	ehdr.e_ident[EI_MAG1] = ELFMAG1;

==== //depot/projects/smpng/sys/amd64/amd64/fpu.c#9 (text+ko) ====

@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/amd64/amd64/fpu.c,v 1.157 2005/03/11 22:16:09 peter Exp $");
+__FBSDID("$FreeBSD: src/sys/amd64/amd64/fpu.c,v 1.158 2006/04/19 07:00:19 cperciva Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -96,6 +96,8 @@
 
 typedef u_char bool_t;
 
+static	void	fpu_clean_state(void);
+
 int	hw_float = 1;
 SYSCTL_INT(_hw,HW_FLOATINGPT, floatingpoint,
 	CTLFLAG_RD, &hw_float, 0, 
@@ -407,6 +409,8 @@
 	PCPU_SET(fpcurthread, curthread);
 	pcb = PCPU_GET(curpcb);
 
+	fpu_clean_state();
+
 	if ((pcb->pcb_flags & PCB_FPUINITDONE) == 0) {
 		/*
 		 * This is the first time this thread has used the FPU,
@@ -474,6 +478,7 @@
 
 	s = intr_disable();
 	if (td == PCPU_GET(fpcurthread)) {
+		fpu_clean_state();
 		fxrstor(addr);
 		intr_restore(s);
 	} else {
@@ -484,6 +489,37 @@
 }
 
 /*
+ * On AuthenticAMD processors, the fxrstor instruction does not restore
+ * the x87's stored last instruction pointer, last data pointer, and last
+ * opcode values, except in the rare case in which the exception summary
+ * (ES) bit in the x87 status word is set to 1.
+ *
+ * In order to avoid leaking this information across processes, we clean
+ * these values by performing a dummy load before executing fxrstor().
+ */
+static	double	dummy_variable = 0.0;
+static void
+fpu_clean_state(void)
+{
+	u_short status;
+
+	/*
+	 * Clear the ES bit in the x87 status word if it is currently
+	 * set, in order to avoid causing a fault in the upcoming load.
+	 */
+	fnstsw(&status);
+	if (status & 0x80)
+		fnclex();
+
+	/*
+	 * Load the dummy variable into the x87 stack.  This mangles
+	 * the x87 stack, but we don't care since we're about to call
+	 * fxrstor() anyway.
+	 */
+	__asm __volatile("ffree %%st(7); fld %0" : : "m" (dummy_variable));
+}
+
+/*
  * This really sucks.  We want the acpi version only, but it requires
  * the isa_if.h file in order to get the definitions.
  */

==== //depot/projects/smpng/sys/amd64/amd64/identcpu.c#18 (text+ko) ====

@@ -39,7 +39,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/amd64/amd64/identcpu.c,v 1.144 2006/02/15 14:48:59 dwmalone Exp $");
+__FBSDID("$FreeBSD: src/sys/amd64/amd64/identcpu.c,v 1.146 2006/04/24 22:56:57 jkim Exp $");
 
 #include "opt_cpu.h"
 
@@ -233,7 +233,7 @@
 				"\014<b11>"
 				"\015<b12>"
 				"\016CX16"	/* CMPXCHG16B Instruction */
-				"\017<b14>"
+				"\017XTPR"	/* Send Task Priority Messages*/
 				"\020<b15>"
 				"\021<b16>"
 				"\022<b17>"
@@ -360,7 +360,8 @@
 			else if (strcmp(cpu_vendor, "GenuineIntel") == 0 &&
 			    (cpu_high >= 4)) {
 				cpuid_count(4, 0, regs);
-				cmp = ((regs[0] & 0xfc000000) >> 26) + 1;
+				if ((regs[0] & 0x1f) != 0)
+					cmp = ((regs[0] >> 26) & 0x3f) + 1;
 			}
 			if (cmp > 1)
 				printf("\n  Cores per package: %d", cmp);

==== //depot/projects/smpng/sys/amd64/amd64/mp_machdep.c#36 (text+ko) ====

@@ -25,7 +25,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/amd64/amd64/mp_machdep.c,v 1.271 2006/03/18 19:32:46 ups Exp $");
+__FBSDID("$FreeBSD: src/sys/amd64/amd64/mp_machdep.c,v 1.273 2006/04/25 00:06:37 jkim Exp $");
 
 #include "opt_cpu.h"
 #include "opt_kstack_pages.h"
@@ -183,6 +183,7 @@
 mp_topology(void)
 {
 	struct cpu_group *group;
+	u_int regs[4];
 	int logical_cpus;
 	int apic_id;
 	int groups;
@@ -195,6 +196,13 @@
 	logical_cpus = (cpu_procinfo & CPUID_HTT_CORES) >> 16;
 	if (logical_cpus <= 1)
 		return;
+	/* Nothing to do if reported cores are physical cores. */
+	if (strcmp(cpu_vendor, "GenuineIntel") == 0 && cpu_high >= 4) {
+		cpuid_count(4, 0, regs);
+		if ((regs[0] & 0x1f) != 0 &&
+		    logical_cpus <= ((regs[0] >> 26) & 0x3f) + 1)
+			return;
+	}
 	group = &mp_groups[0];
 	groups = 1;
 	for (cpu = 0, apic_id = 0; apic_id < MAXCPU; apic_id++) {
@@ -385,8 +393,8 @@
 		 * are available, use them.
 		 */
 		if (cpu_high >= 4) {
-			/* Ask the processor about up to 32 caches. */
-			for (i = 0; i < 32; i++) {
+			/* Ask the processor about the L1 cache. */
+			for (i = 0; i < 1; i++) {
 				cpuid_count(4, i, p);
 				threads_per_cache = ((p[0] & 0x3ffc000) >> 14) + 1;
 				if (hyperthreading_cpus < threads_per_cache)

==== //depot/projects/smpng/sys/amd64/amd64/nexus.c#18 (text+ko) ====

@@ -28,7 +28,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/amd64/amd64/nexus.c,v 1.67 2005/09/25 20:03:41 phk Exp $");
+__FBSDID("$FreeBSD: src/sys/amd64/amd64/nexus.c,v 1.68 2006/04/20 04:16:34 imp Exp $");
 
 /*
  * This code implements a `root nexus' for Intel Architecture
@@ -340,7 +340,7 @@
 	rv = rman_reserve_resource(rm, start, end, count, flags, child);
 	if (rv == 0)
 		return 0;
-
+	rman_set_rid(rv, *rid);
 	if (type == SYS_RES_MEMORY) {
 		rman_set_bustag(rv, AMD64_BUS_SPACE_MEM);
 	} else if (type == SYS_RES_IOPORT) {

==== //depot/projects/smpng/sys/amd64/amd64/pmap.c#55 (text+ko) ====

@@ -77,7 +77,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/amd64/amd64/pmap.c,v 1.545 2006/04/13 03:31:48 alc Exp $");
+__FBSDID("$FreeBSD: src/sys/amd64/amd64/pmap.c,v 1.549 2006/04/21 04:50:18 peter Exp $");
 
 /*
  *	Manages physical address maps.
@@ -181,7 +181,7 @@
 
 static u_int64_t	KPTphys;	/* phys addr of kernel level 1 */
 static u_int64_t	KPDphys;	/* phys addr of kernel level 2 */
-static u_int64_t	KPDPphys;	/* phys addr of kernel level 3 */
+u_int64_t		KPDPphys;	/* phys addr of kernel level 3 */
 u_int64_t		KPML4phys;	/* phys addr of kernel level 4 */
 
 static u_int64_t	DMPDphys;	/* phys addr of direct mapped level 2 */
@@ -1547,7 +1547,7 @@
 
 	PV_STAT(pv_entry_frees++);
 	PV_STAT(pv_entry_spare++);
-	PV_STAT(pv_entry_count--);
+	pv_entry_count--;
 	pc = pv_to_chunk(pv);
 	idx = pv - &pc->pc_pventry[0];
 	field = idx / 64;
@@ -1565,6 +1565,7 @@
 	/* entire chunk is free, return it */
 	TAILQ_REMOVE(&pmap->pm_pvchunk, pc, pc_list);
 	m = PHYS_TO_VM_PAGE(DMAP_TO_PHYS((vm_offset_t)pc));
+	dump_drop_page(m->phys_addr);
 	vm_page_lock_queues();
 	vm_page_free(m);
 	vm_page_unlock_queues();
@@ -1588,7 +1589,7 @@
 	PMAP_LOCK_ASSERT(pmap, MA_OWNED);
 	mtx_assert(&vm_page_queue_mtx, MA_OWNED);
 	PV_STAT(pv_entry_allocs++);
-	PV_STAT(pv_entry_count++);
+	pv_entry_count++;
 	if (pv_entry_count > pv_entry_high_water)
 		pagedaemon_wakeup();
 	pc = TAILQ_FIRST(&pmap->pm_pvchunk);
@@ -1616,6 +1617,7 @@
 	m = vm_page_alloc(NULL, colour, VM_ALLOC_SYSTEM | VM_ALLOC_NOOBJ);
 	if (m == NULL) {
 		if (try) {
+			pv_entry_count--;
 			PV_STAT(pc_chunk_tryfail++);
 			return (NULL);
 		}
@@ -1644,6 +1646,7 @@
 	PV_STAT(pc_chunk_count++);
 	PV_STAT(pc_chunk_allocs++);
 	colour++;
+	dump_add_page(m->phys_addr);
 	pc = (void *)PHYS_TO_DMAP(m->phys_addr);
 	pc->pc_pmap = pmap;
 	pc->pc_map[0] = PC_FREE0 & ~1ul;	/* preallocated bit 0 */
@@ -2777,7 +2780,7 @@
 				/* Mark free */
 				PV_STAT(pv_entry_frees++);
 				PV_STAT(pv_entry_spare++);
-				PV_STAT(pv_entry_count--);
+				pv_entry_count--;
 				pc->pc_map[field] |= bitmask;
 				m->md.pv_list_count--;
 				TAILQ_REMOVE(&m->md.pv_list, pv, pv_list);
@@ -2793,6 +2796,7 @@
 			PV_STAT(pc_chunk_frees++);
 			TAILQ_REMOVE(&pmap->pm_pvchunk, pc, pc_list);
 			m = PHYS_TO_VM_PAGE(DMAP_TO_PHYS((vm_offset_t)pc));
+			dump_drop_page(m->phys_addr);
 			vm_page_lock_queues();
 			vm_page_free(m);
 			vm_page_unlock_queues();

==== //depot/projects/smpng/sys/amd64/amd64/uma_machdep.c#2 (text+ko) ====

@@ -25,7 +25,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/amd64/amd64/uma_machdep.c,v 1.1 2003/10/14 05:51:31 alc Exp $");
+__FBSDID("$FreeBSD: src/sys/amd64/amd64/uma_machdep.c,v 1.2 2006/04/21 04:24:50 peter Exp $");
 
 #include <sys/param.h>
 #include <sys/lock.h>
@@ -44,6 +44,7 @@
 {
 	static vm_pindex_t colour;
 	vm_page_t m;
+	vm_paddr_t pa;
 	void *va;
 	int pflags;
 
@@ -64,7 +65,9 @@
 		} else
 			break;
 	}
-	va = (void *)PHYS_TO_DMAP(m->phys_addr);
+	pa = m->phys_addr;
+	dump_add_page(pa);
+	va = (void *)PHYS_TO_DMAP(pa);
 	if ((wait & M_ZERO) && (m->flags & PG_ZERO) == 0)
 		pagezero(va);
 	return (va);
@@ -74,8 +77,11 @@
 uma_small_free(void *mem, int size, u_int8_t flags)
 {
 	vm_page_t m;
+	vm_paddr_t pa;
 
-	m = PHYS_TO_VM_PAGE(DMAP_TO_PHYS((vm_offset_t)mem));
+	pa = DMAP_TO_PHYS((vm_offset_t)mem);
+	dump_drop_page(pa);
+	m = PHYS_TO_VM_PAGE(pa);
 	vm_page_lock_queues();
 	vm_page_free(m);
 	vm_page_unlock_queues();

==== //depot/projects/smpng/sys/amd64/conf/GENERIC#43 (text+ko) ====

@@ -16,7 +16,7 @@
 # If you are in doubt as to the purpose or necessity of a line, check first
 # in NOTES.
 #
-# $FreeBSD: src/sys/amd64/conf/GENERIC,v 1.452 2006/04/10 20:04:22 ps Exp $
+# $FreeBSD: src/sys/amd64/conf/GENERIC,v 1.453 2006/04/24 08:44:33 delphij Exp $
 
 cpu		HAMMER
 ident		GENERIC
@@ -57,10 +57,6 @@
 options 	SYSVSEM			# SYSV-style semaphores
 options 	_KPOSIX_PRIORITY_SCHEDULING # POSIX P1003_1B real-time extensions
 options 	KBD_INSTALL_CDEV	# install a CDEV entry in /dev
-options 	AHC_REG_PRETTY_PRINT	# Print register bitfields in debug
-					# output.  Adds ~128k to driver.
-options 	AHD_REG_PRETTY_PRINT	# Print register bitfields in debug
-					# output.  Adds ~215k to driver.
 options 	ADAPTIVE_GIANT		# Giant mutex is adaptive.
 options 	STOP_NMI		# Stop CPUS using NMI instead of IPI
 
@@ -98,7 +94,11 @@
 
 # SCSI Controllers
 device		ahc		# AHA2940 and onboard AIC7xxx devices
+options 	AHC_REG_PRETTY_PRINT	# Print register bitfields in debug
+					# output.  Adds ~128k to driver.
 device		ahd		# AHA39320/29320 and onboard AIC79xx devices
+options 	AHD_REG_PRETTY_PRINT	# Print register bitfields in debug
+					# output.  Adds ~215k to driver.
 device		amd		# AMD 53C974 (Tekram DC-390(T))
 device		isp		# Qlogic family
 #device 	ispfw		# Firmware for QLogic HBAs- normally a module

==== //depot/projects/smpng/sys/amd64/include/md_var.h#12 (text+ko) ====

@@ -26,7 +26,7 @@
  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  * SUCH DAMAGE.
  *
- * $FreeBSD: src/sys/amd64/include/md_var.h,v 1.76 2005/10/14 22:52:00 jkim Exp $
+ * $FreeBSD: src/sys/amd64/include/md_var.h,v 1.77 2006/04/21 04:24:50 peter Exp $
  */
 
 #ifndef _MACHINE_MD_VAR_H_
@@ -53,6 +53,8 @@
 extern	char	kstack[];
 extern	char	sigcode[];
 extern	int	szsigcode;
+extern	uint64_t *vm_page_dump;
+extern	int	vm_page_dump_size;
 
 extern	struct pcpu __pcpu[];
 
@@ -61,11 +63,14 @@
 struct	reg;
 struct	fpreg;
 struct  dbreg;
+struct	dumperinfo;
 
 void	busdma_swi(void);
 void	cpu_setregs(void);
 void	doreti_iret(void) __asm(__STRING(doreti_iret));
 void	doreti_iret_fault(void) __asm(__STRING(doreti_iret_fault));
+void	dump_add_page(vm_paddr_t);
+void	dump_drop_page(vm_paddr_t);
 void	initializecpu(void);
 void	fillw(int /*u_short*/ pat, void *base, size_t cnt);
 void	fpstate_drop(struct thread *td);
@@ -75,5 +80,6 @@
 void	pagezero(void *addr);
 void	setidt(int idx, alias_for_inthand_t *func, int typ, int dpl, int ist);
 int	user_dbreg_trap(void);
+void	minidumpsys(struct dumperinfo *);
 
 #endif /* !_MACHINE_MD_VAR_H_ */

==== //depot/projects/smpng/sys/arm/arm/nexus.c#7 (text+ko) ====

@@ -40,7 +40,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/arm/arm/nexus.c,v 1.6 2005/09/25 21:06:49 cognet Exp $");
+__FBSDID("$FreeBSD: src/sys/arm/arm/nexus.c,v 1.7 2006/04/20 04:12:02 imp Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -214,6 +214,7 @@
 	if (rv == 0)
 		return 0;
 
+	rman_set_rid(rv, *rid);
 	rman_set_bustag(rv, (void*)ARM_BUS_SPACE_MEM);
 	rman_set_bushandle(rv, rman_get_start(rv));		
 	

==== //depot/projects/smpng/sys/arm/arm/pmap.c#27 (text+ko) ====

@@ -147,7 +147,7 @@
 #include "opt_vm.h"
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/arm/arm/pmap.c,v 1.46 2006/04/03 21:16:07 peter Exp $");
+__FBSDID("$FreeBSD: src/sys/arm/arm/pmap.c,v 1.47 2006/04/22 22:51:32 cognet Exp $");
 #include <sys/param.h>
 #include <sys/systm.h>
 #include <sys/kernel.h>
@@ -1204,18 +1204,6 @@
 }
 
 /*
- * this routine defines the region(s) of memory that should
- * not be tested for the modified bit.
- */
-static PMAP_INLINE int
-pmap_track_modified(vm_offset_t va)
-{
-	if ((va < kmi.clean_sva) || (va >= kmi.clean_eva)) 
-		return 1;
-	else
-		return 0;
-}
-/*
  * PTE_SYNC_CURRENT:
  *
  *     Make sure the pte is written out to RAM.
@@ -1559,8 +1547,7 @@
 		ptep = &l2b->l2b_kva[l2pte_index(va)];
 		npte = opte = *ptep;
 
-		if (maskbits & (PVF_WRITE|PVF_MOD) &&
-		    !pmap_track_modified(pv->pv_va)) {
+		if (maskbits & (PVF_WRITE|PVF_MOD)) {
 			if ((pv->pv_flags & PVF_NC)) {
 				/* 
 				 * Entry is not cacheable:
@@ -1618,7 +1605,7 @@
 			}
 		}
 
-		if (maskbits & PVF_REF && !pmap_track_modified(pv->pv_va)) {
+		if (maskbits & PVF_REF) {
 			if ((pv->pv_flags & PVF_NC) == 0 &&
 			    (maskbits & (PVF_WRITE|PVF_MOD)) == 0) {
 				/*
@@ -2056,10 +2043,8 @@
 			goto out;
 		}
 
-		if (pmap_track_modified(pv->pv_va)) {
-			pg->md.pvh_attrs |= PVF_REF | PVF_MOD;
-			vm_page_dirty(pg);
-		}
+		pg->md.pvh_attrs |= PVF_REF | PVF_MOD;
+		vm_page_dirty(pg);
 		pv->pv_flags |= PVF_REF | PVF_MOD;
 
 		/* 
@@ -3267,8 +3252,7 @@
 					f = pmap_modify_pv(pg, pm, sva,
 					    PVF_WRITE, 0);
 					pmap_vac_me_harder(pg, pm, sva);
-					if (pmap_track_modified(sva))
-						vm_page_dirty(pg);
+					vm_page_dirty(pg);
 				} else
 					f = PVF_REF | PVF_EXEC;
 
@@ -3391,8 +3375,7 @@
 			 * writable from the outset.
 			 */
 			nflags |= PVF_MOD;
-			if (!(m->md.pvh_attrs & PVF_MOD) &&
-			    pmap_track_modified(va))
+			if (!(m->md.pvh_attrs & PVF_MOD))
 				vm_page_dirty(m);
 		}
 		if (m && opte)
@@ -3477,8 +3460,11 @@
 			if ((pve = pmap_get_pv_entry()) == NULL) {
 				panic("pmap_enter: no pv entries");	
 			}
-		if (m && !(m->flags & (PG_UNMANAGED | PG_FICTITIOUS)))
+		if (m && !(m->flags & (PG_UNMANAGED | PG_FICTITIOUS))) {
+			KASSERT(va < kmi.clean_sva || va >= kmi.clean_eva,
+			    ("pmap_enter: managed mapping within the clean submap"));
 			pmap_enter_pv(m, pve, pmap, va, nflags);
+		}
 	}
 	/*
 	 * Make sure userland mappings get the right permissions

==== //depot/projects/smpng/sys/arm/at91/at91.c#4 (text) ====

@@ -23,7 +23,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/arm/at91/at91.c,v 1.4 2006/04/06 04:32:29 imp Exp $");
+__FBSDID("$FreeBSD: src/sys/arm/at91/at91.c,v 1.5 2006/04/20 04:12:02 imp Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -497,6 +497,7 @@
 		rle->start = rman_get_start(rle->res);
 		rle->end = rman_get_end(rle->res);
 		rle->count = count;
+		rman_set_rid(rle->res, *rid);
 	}
 	return (rle->res);
 }

==== //depot/projects/smpng/sys/arm/sa11x0/sa11x0.c#6 (text+ko) ====

@@ -57,7 +57,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/arm/sa11x0/sa11x0.c,v 1.5 2005/09/25 21:06:50 cognet Exp $");
+__FBSDID("$FreeBSD: src/sys/arm/sa11x0/sa11x0.c,v 1.6 2006/04/20 04:12:02 imp Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -127,6 +127,8 @@
 	
 	res = rman_reserve_resource(&sa11x0_softc->sa11x0_rman, *rid, *rid,
 	    count, flags, child);
+	if (res != NULL)
+		rman_set_rid(res, *rid);
 
 	return (res);
 }

==== //depot/projects/smpng/sys/arm/xscale/i80321/i80321_pci.c#8 (text+ko) ====

@@ -40,7 +40,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/arm/xscale/i80321/i80321_pci.c,v 1.7 2006/04/13 15:07:59 cognet Exp $");
+__FBSDID("$FreeBSD: src/sys/arm/xscale/i80321/i80321_pci.c,v 1.8 2006/04/20 04:12:02 imp Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -380,6 +380,7 @@
 	rv = rman_reserve_resource(rm, start, end, count, flags, child);
 	if (rv == NULL)
 		return (NULL);
+	rman_set_rid(rv, *rid);
 	if (type != SYS_RES_IRQ) {
 		if (type == SYS_RES_MEMORY)
 			bh += (rman_get_start(rv));

==== //depot/projects/smpng/sys/arm/xscale/i80321/iq80321.c#9 (text+ko) ====

@@ -42,7 +42,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/arm/xscale/i80321/iq80321.c,v 1.10 2005/10/03 14:19:55 cognet Exp $");
+__FBSDID("$FreeBSD: src/sys/arm/xscale/i80321/iq80321.c,v 1.11 2006/04/20 04:12:02 imp Exp $");
 
 #define _ARM32_BUS_DMA_PRIVATE
 #include <sys/param.h>
@@ -300,10 +300,14 @@
     u_long start, u_long end, u_long count, u_int flags)
 {
 	struct i80321_softc *sc = device_get_softc(dev);
-	
-	if (type == SYS_RES_IRQ) 
-		return (rman_reserve_resource(&sc->sc_irq_rman,
-		    start, end, count, flags, child));
+	struct resource *rv;
+
+	if (type == SYS_RES_IRQ) {
+		rv = rman_reserve_resource(&sc->sc_irq_rman,
+		    start, end, count, flags, child);
+		if (rv != NULL)
+			rman_set_rid(rv, *rid);
+	}
 	return (NULL);
 }
 

==== //depot/projects/smpng/sys/arm/xscale/i80321/obio.c#4 (text+ko) ====

@@ -41,7 +41,7 @@
  */
 
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/arm/xscale/i80321/obio.c,v 1.3 2005/09/25 21:06:50 cognet Exp $");
+__FBSDID("$FreeBSD: src/sys/arm/xscale/i80321/obio.c,v 1.4 2006/04/20 04:12:02 imp Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -124,6 +124,7 @@
 		return (NULL);
 	if (type == SYS_RES_IRQ)
 		return (rv);
+	rman_set_rid(rv, *rid);
 	rman_set_bustag(rv, bt);
 	rman_set_bushandle(rv, bh);
 	

==== //depot/projects/smpng/sys/boot/arm/at91/boot0/Makefile#2 (text) ====


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



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