Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 5 Jun 2006 05:39:12 GMT
From:      Kip Macy <kmacy@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 98521 for review
Message-ID:  <200606050539.k555dCNc029207@repoman.freebsd.org>

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

Change 98521 by kmacy@kmacy_storage:sun4v_work_test on 2006/06/05 05:38:27

	fix breakage caused by previous IFC
	integrate bike_sched
	fix sun4v bike_sched dependencies

Affected files ...

.. //depot/projects/kmacy_sun4v/src/sys/amd64/amd64/machdep.c#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/amd64/amd64/trap.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/amd64/amd64/vm_machdep.c#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/arm/arm/trap.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/arm/arm/vm_machdep.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/arm/at91/kb920x_machdep.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/arm/sa11x0/assabet_machdep.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/arm/xscale/i80321/iq31244_machdep.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/boot/sparc64/loader/main.c#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/conf/files#7 edit
.. //depot/projects/kmacy_sun4v/src/sys/conf/options#8 edit
.. //depot/projects/kmacy_sun4v/src/sys/ddb/db_ps.c#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/dev/em/if_em.c#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/dev/isp/isp_pci.c#6 integrate
.. //depot/projects/kmacy_sun4v/src/sys/dev/mpt/mpt_pci.c#6 integrate
.. //depot/projects/kmacy_sun4v/src/sys/dev/ofw/openfirm.h#8 integrate
.. //depot/projects/kmacy_sun4v/src/sys/dev/pci/pci_pci.c#9 integrate
.. //depot/projects/kmacy_sun4v/src/sys/dev/pci/pcireg.h#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/i386/i386/machdep.c#6 integrate
.. //depot/projects/kmacy_sun4v/src/sys/i386/i386/sys_machdep.c#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/i386/i386/trap.c#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/i386/i386/vm_machdep.c#6 integrate
.. //depot/projects/kmacy_sun4v/src/sys/ia64/ia64/machdep.c#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/ia64/ia64/trap.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/init_main.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/init_sysent.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_clock.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_fork.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_idle.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_intr.c#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_kse.c#3 delete
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_mutex.c#7 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_poll.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_proc.c#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_resource.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_sig.c#6 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_subr.c#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_switch.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_synch.c#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_thr.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/kern_thread.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/sched_4bsd.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/sched_ule.c#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/subr_bus.c#8 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/subr_rman.c#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/subr_trap.c#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/sys_process.c#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/syscalls.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/syscalls.master#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/kern/tty.c#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/pc98/pc98/machdep.c#6 integrate
.. //depot/projects/kmacy_sun4v/src/sys/posix4/ksched.c#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/powerpc/powerpc/machdep.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/powerpc/powerpc/trap.c#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/sparc64/sparc64/genassym.c#22 edit
.. //depot/projects/kmacy_sun4v/src/sys/sparc64/sparc64/machdep.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/sparc64/sparc64/trap.c#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/conf/GENERIC#15 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/machdep.c#25 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/pmap.c#62 edit
.. //depot/projects/kmacy_sun4v/src/sys/sun4v/sun4v/trap.c#13 edit
.. //depot/projects/kmacy_sun4v/src/sys/sys/bus.h#6 integrate
.. //depot/projects/kmacy_sun4v/src/sys/sys/mutex.h#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/sys/proc.h#5 integrate
.. //depot/projects/kmacy_sun4v/src/sys/sys/rtprio.h#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/sys/sched.h#3 integrate
.. //depot/projects/kmacy_sun4v/src/sys/sys/syscall.h#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/sys/syscall.mk#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/sys/sysproto.h#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/ufs/ffs/ffs_vfsops.c#8 integrate
.. //depot/projects/kmacy_sun4v/src/sys/vm/vm_glue.c#4 integrate
.. //depot/projects/kmacy_sun4v/src/sys/vm/vm_zeroidle.c#4 integrate

Differences ...

==== //depot/projects/kmacy_sun4v/src/sys/amd64/amd64/machdep.c#5 (text+ko) ====

@@ -1137,7 +1137,7 @@
  	 * This may be done better later if it gets more high level
  	 * components in it. If so just link td->td_proc here.
 	 */
-	proc_linkup(&proc0, &ksegrp0, &thread0);
+	proc_linkup(&proc0, &thread0);
 
 	preload_metadata = (caddr_t)(uintptr_t)(modulep + KERNBASE);
 	preload_bootstrap_relocate(KERNBASE);

==== //depot/projects/kmacy_sun4v/src/sys/amd64/amd64/trap.c#4 (text+ko) ====

@@ -301,8 +301,6 @@
 
 		case T_PAGEFLT:		/* page fault */
 			addr = frame.tf_addr;
-			if (td->td_pflags & TDP_SA)
-				thread_user_enter(td);
 			i = trap_pfault(&frame, TRUE);
 			if (i == -1)
 				goto userout;
@@ -759,8 +757,6 @@
 	td->td_frame = &frame;
 	if (td->td_ucred != p->p_ucred) 
 		cred_update_thread(td);
-	if (p->p_flag & P_SA)
-		thread_user_enter(td);
 	params = (caddr_t)frame.tf_rsp + sizeof(register_t);
 	code = frame.tf_rax;
 	orig_tf_rflags = frame.tf_rflags;

==== //depot/projects/kmacy_sun4v/src/sys/amd64/amd64/vm_machdep.c#3 (text+ko) ====

@@ -244,8 +244,7 @@
  * Initialize machine state (pcb and trap frame) for a new thread about to
  * upcall. Put enough state in the new thread's PCB to get it to go back 
  * userret(), where we can intercept it again to set the return (upcall)
- * Address and stack, along with those from upcals that are from other sources
- * such as those generated in thread_userret() itself.
+ * Address and stack, along with those from upcals that are from other sources.
  */
 void
 cpu_set_upcall(struct thread *td, struct thread *td0)
@@ -302,24 +301,14 @@
 }
 
 /*
- * Set that machine state for performing an upcall that has to
- * be done in thread_userret() so that those upcalls generated
- * in thread_userret() itself can be done as well.
+ * Modify the machine state created by cpu_set_upcall() to arrange
+ * for the new thread to make a specific call as its first act.
  */
 void
 cpu_set_upcall_kse(struct thread *td, void (*entry)(void *), void *arg,
 	stack_t *stack)
 {
 
-	/* 
-	 * Do any extra cleaning that needs to be done.
-	 * The thread may have optional components
-	 * that are not present in a fresh thread.
-	 * This may be a recycled thread so make it look
-	 * as though it's newly allocated.
-	 */
-	cpu_thread_clean(td);
-
 	/*
 	 * Set the trap frame to point at the beginning of the uts
 	 * function.

==== //depot/projects/kmacy_sun4v/src/sys/arm/arm/trap.c#4 (text+ko) ====

@@ -264,8 +264,6 @@
 		td->td_frame = tf;		
 		if (td->td_ucred != td->td_proc->p_ucred)
 			cred_update_thread(td);
-		if (td->td_pflags & TDP_SA)
-			thread_user_enter(td);
 		
 	}
 	/* Grab the current pcb */
@@ -731,8 +729,6 @@
 		td->td_frame = tf;
 		if (td->td_ucred != td->td_proc->p_ucred)
 			cred_update_thread(td);
-		if (td->td_proc->p_flag & P_SA)
-			thread_user_enter(td);
 	}
 	fault_pc = tf->tf_pc;
 	if (td->td_md.md_spinlock_count == 0) {
@@ -1004,8 +1000,6 @@
 	td->td_frame = frame;
 	
 	td->td_pticks = 0;
-	if (td->td_proc->p_flag & P_SA)
-		thread_user_enter(td);
 	/*
       	 * Make sure the program counter is correctly aligned so we
 	 * don't take an alignment fault trying to read the opcode.

==== //depot/projects/kmacy_sun4v/src/sys/arm/arm/vm_machdep.c#4 (text+ko) ====

@@ -256,8 +256,7 @@
  * Initialize machine state (pcb and trap frame) for a new thread about to
  * upcall. Put enough state in the new thread's PCB to get it to go back 
  * userret(), where we can intercept it again to set the return (upcall)
- * Address and stack, along with those from upcals that are from other sources
- * such as those generated in thread_userret() itself.
+ * Address and stack, along with those from upcals that are from other sources.
  */
 void
 cpu_set_upcall(struct thread *td, struct thread *td0)
@@ -283,9 +282,8 @@
 }
 
 /*
- * Set that machine state for performing an upcall that has to
- * be done in thread_userret() so that those upcalls generated
- * in thread_userret() itself can be done as well.
+ * Modify the machine state created by cpu_set_upcall() to arrange
+ * for the new thread to make a specific call as its first act.
  */
 void
 cpu_set_upcall_kse(struct thread *td, void (*entry)(void *), void *arg,

==== //depot/projects/kmacy_sun4v/src/sys/arm/at91/kb920x_machdep.c#4 (text+ko) ====

@@ -382,7 +382,7 @@
 	undefined_handler_address = (u_int)undefinedinstruction_bounce;
 	undefined_init();
 				
-	proc_linkup(&proc0, &ksegrp0, &thread0);
+	proc_linkup(&proc0, &thread0);
 	thread0.td_kstack = kernelstack.pv_va;
 	thread0.td_pcb = (struct pcb *)
 		(thread0.td_kstack + KSTACK_PAGES * PAGE_SIZE) - 1;

==== //depot/projects/kmacy_sun4v/src/sys/arm/sa11x0/assabet_machdep.c#4 (text+ko) ====

@@ -413,7 +413,7 @@
 
 	/* Set stack for exception handlers */
 	
-	proc_linkup(&proc0, &ksegrp0, &thread0);
+	proc_linkup(&proc0, &thread0);
 	thread0.td_kstack = kernelstack.pv_va;
 	thread0.td_pcb = (struct pcb *)
 		(thread0.td_kstack + KSTACK_PAGES * PAGE_SIZE) - 1;

==== //depot/projects/kmacy_sun4v/src/sys/arm/xscale/i80321/iq31244_machdep.c#4 (text+ko) ====

@@ -428,7 +428,7 @@
 	undefined_handler_address = (u_int)undefinedinstruction_bounce;
 	undefined_init();
 				
-	proc_linkup(&proc0, &ksegrp0, &thread0);
+	proc_linkup(&proc0, &thread0);
 	thread0.td_kstack = kernelstack.pv_va;
 	thread0.td_pcb = (struct pcb *)
 		(thread0.td_kstack + KSTACK_PAGES * PAGE_SIZE) - 1;

==== //depot/projects/kmacy_sun4v/src/sys/boot/sparc64/loader/main.c#5 (text+ko) ====


==== //depot/projects/kmacy_sun4v/src/sys/conf/files#7 (text+ko) ====

@@ -1,4 +1,4 @@
-# $FreeBSD: src/sys/conf/files,v 1.1118 2006/05/18 23:30:47 ambrisko Exp $
+# $FreeBSD: src/sys/conf/files,v 1.1119 2006/05/27 16:32:05 netchild Exp $
 #
 # The long compile-with and dependency lines are required because of
 # limitations in config: backslash-newline doesn't work in strings, and
@@ -905,6 +905,12 @@
 #dev/sound/usb/upcm.c		optional snd_upcm usb
 dev/sound/usb/uaudio.c		optional snd_uaudio usb
 dev/sound/usb/uaudio_pcm.c	optional snd_uaudio usb
+dev/sound/midi/midi.c		optional sound
+dev/sound/midi/mpu401.c		optional sound
+dev/sound/midi/mpu_if.m		optional sound
+dev/sound/midi/mpufoi_if.m	optional sound
+dev/sound/midi/sequencer.c	optional sound
+dev/sound/midi/synth_if.m	optional sound
 dev/sr/if_sr.c			optional sr
 dev/sr/if_sr_pci.c		optional sr pci
 dev/stg/tmc18c30.c		optional stg
@@ -1273,7 +1279,6 @@
 kern/kern_idle.c		standard
 kern/kern_intr.c		standard
 kern/kern_jail.c		standard
-kern/kern_kse.c			standard
 kern/kern_kthread.c		standard
 kern/kern_ktr.c			optional ktr
 kern/kern_ktrace.c		standard
@@ -1378,6 +1383,7 @@
 kern/uipc_sem.c			optional p1003_1b_semaphores
 kern/uipc_socket.c		standard
 kern/uipc_socket2.c		standard
+kern/uipc_stub.c		optional uipc_stub
 kern/uipc_syscalls.c		standard
 kern/uipc_usrreq.c		standard
 kern/vfs_aio.c			optional vfs_aio

==== //depot/projects/kmacy_sun4v/src/sys/conf/options#8 (text+ko) ====

@@ -168,6 +168,9 @@
 P1003_1B_SEMAPHORES		opt_posix.h
 _KPOSIX_PRIORITY_SCHEDULING	opt_posix.h
 
+# Sample network protocol
+UIPC_STUB	opt_dontuse.h
+
 # Do we want the config file compiled into the kernel?
 INCLUDE_CONFIG_FILE	opt_config.h
 

==== //depot/projects/kmacy_sun4v/src/sys/ddb/db_ps.c#5 (text+ko) ====

@@ -295,7 +295,6 @@
 
 	db_printf("Thread %d at %p:\n", td->td_tid, td);
 	db_printf(" proc (pid %d): %p ", td->td_proc->p_pid, td->td_proc);
-	db_printf(" ksegrp: %p\n", td->td_ksegrp);
 	if (td->td_name[0] != '\0')
 		db_printf(" name: %s\n", td->td_name);
 	db_printf(" flags: %#x ", td->td_flags);

==== //depot/projects/kmacy_sun4v/src/sys/dev/em/if_em.c#5 (text+ko) ====


==== //depot/projects/kmacy_sun4v/src/sys/dev/isp/isp_pci.c#6 (text+ko) ====

@@ -1346,8 +1346,8 @@
 
 	ISP_UNLOCK(isp);
 	if (isp_dma_tag_create(bus_get_dma_tag(pcs->pci_dev), 1, slim, llim,
-	    hlim, NULL, NULL, BUS_SPACE_MAXSIZE, ISP_NSEGS, slim, 0,
-	    &pcs->dmat)) {
+	    hlim, NULL, NULL, BUS_SPACE_MAXSIZE, ISP_NSEGS, slim, 0, 
+	    busdma_lock_mutex, &Giant, &pcs->dmat)) {
 		isp_prt(isp, ISP_LOGERR, "could not create master dma tag");
 		ISP_LOCK(isp);
 		return (1);

==== //depot/projects/kmacy_sun4v/src/sys/dev/mpt/mpt_pci.c#6 (text+ko) ====


==== //depot/projects/kmacy_sun4v/src/sys/dev/ofw/openfirm.h#8 (text+ko) ====


==== //depot/projects/kmacy_sun4v/src/sys/dev/pci/pci_pci.c#9 (text+ko) ====


==== //depot/projects/kmacy_sun4v/src/sys/dev/pci/pcireg.h#5 (text+ko) ====


==== //depot/projects/kmacy_sun4v/src/sys/i386/i386/machdep.c#6 (text+ko) ====

@@ -2071,7 +2071,7 @@
  	 * This may be done better later if it gets more high level
  	 * components in it. If so just link td->td_proc here.
 	 */
-	proc_linkup(&proc0, &ksegrp0, &thread0);
+	proc_linkup(&proc0, &thread0);
 
 	metadata_missing = 0;
 	if (bootinfo.bi_modulep) {

==== //depot/projects/kmacy_sun4v/src/sys/i386/i386/sys_machdep.c#3 (text+ko) ====

@@ -233,9 +233,6 @@
 		0			/* granularity */
 	};
 
-	if (td->td_proc->p_flag & P_SA)
-		return (EINVAL);		/* XXXKSE */
-/* XXXKSE  All the code below only works in 1:1   needs changing */
 	ext = (struct pcb_ext *)kmem_alloc(kernel_map, ctob(IOPAGES+1));
 	if (ext == 0)
 		return (ENOMEM);

==== //depot/projects/kmacy_sun4v/src/sys/i386/i386/trap.c#3 (text+ko) ====

@@ -348,9 +348,6 @@
 			break;
 
 		case T_PAGEFLT:		/* page fault */
-			if (td->td_pflags & TDP_SA)
-				thread_user_enter(td);
-
 			i = trap_pfault(&frame, TRUE, eva);
 #if defined(I586_CPU) && !defined(NO_F00F_HACK)
 			if (i == -2) {
@@ -938,8 +935,6 @@
 	td->td_frame = &frame;
 	if (td->td_ucred != p->p_ucred) 
 		cred_update_thread(td);
-	if (p->p_flag & P_SA)
-		thread_user_enter(td);
 	params = (caddr_t)frame.tf_esp + sizeof(int);
 	code = frame.tf_eax;
 	orig_tf_eflags = frame.tf_eflags;

==== //depot/projects/kmacy_sun4v/src/sys/i386/i386/vm_machdep.c#6 (text+ko) ====

@@ -370,8 +370,7 @@
  * Initialize machine state (pcb and trap frame) for a new thread about to
  * upcall. Put enough state in the new thread's PCB to get it to go back 
  * userret(), where we can intercept it again to set the return (upcall)
- * Address and stack, along with those from upcals that are from other sources
- * such as those generated in thread_userret() itself.
+ * Address and stack, along with those from upcals that are from other sources.
  */
 void
 cpu_set_upcall(struct thread *td, struct thread *td0)
@@ -439,9 +438,8 @@
 }
 
 /*
- * Set that machine state for performing an upcall that has to
- * be done in thread_userret() so that those upcalls generated
- * in thread_userret() itself can be done as well.
+ * Modify the machine state created by cpu_set_upcall() to arrange
+ * for the new thread to make a specific call as its first act.
  */
 void
 cpu_set_upcall_kse(struct thread *td, void (*entry)(void *), void *arg,

==== //depot/projects/kmacy_sun4v/src/sys/ia64/ia64/machdep.c#3 (text+ko) ====

@@ -767,7 +767,7 @@
 	msgbufp = (struct msgbuf *)pmap_steal_memory(MSGBUF_SIZE);
 	msgbufinit(msgbufp, MSGBUF_SIZE);
 
-	proc_linkup(&proc0, &ksegrp0, &thread0);
+	proc_linkup(&proc0, &thread0);
 	/*
 	 * Init mapping for kernel stack for proc 0
 	 */

==== //depot/projects/kmacy_sun4v/src/sys/ia64/ia64/trap.c#4 (text+ko) ====

@@ -955,8 +955,6 @@
 	td->td_pticks = 0;
 	if (td->td_ucred != p->p_ucred)
 		cred_update_thread(td);
-	if (p->p_flag & P_SA)
-		thread_user_enter(td);
 
 	if (p->p_sysent->sv_prepsyscall) {
 		/* (*p->p_sysent->sv_prepsyscall)(tf, args, &code, &params); */

==== //depot/projects/kmacy_sun4v/src/sys/kern/init_main.c#4 (text+ko) ====

@@ -95,7 +95,6 @@
 static struct pgrp pgrp0;
 struct	proc proc0;
 struct	thread thread0 __aligned(8);
-struct	ksegrp ksegrp0;
 struct	vmspace vmspace0;
 struct	proc *initproc;
 
@@ -249,6 +248,30 @@
 		}
 #endif
 
+#if defined(VERBOSE_SYSINIT)
+		if ((*sipp)->subsystem > last) {
+			verbose = 1;
+			last = (*sipp)->subsystem;
+			printf("subsystem %x\n", last);
+		}
+		if (verbose) {
+#if defined(DDB)
+			const char *name;
+			c_db_sym_t sym;
+			db_expr_t  offset;
+
+			sym = db_search_symbol((vm_offset_t)(*sipp)->func,
+			    DB_STGY_PROC, &offset);
+			db_symbol_values(sym, &name, NULL);
+			if (name != NULL)
+				printf("   %s(%p)... ", name, (*sipp)->udata);
+			else
+#endif
+				printf("   %p(%p)... ", (*sipp)->func,
+				    (*sipp)->udata);
+		}
+#endif
+
 		/* Call function */
 		(*((*sipp)->func))((*sipp)->udata);
 #if 0
@@ -261,6 +284,11 @@
 			printf("done.\n");
 #endif
 
+#if defined(VERBOSE_SYSINIT)
+		if (verbose)
+			printf("done.\n");
+#endif
+
 		/* Check off the one we're just done */
 		(*sipp)->subsystem = SI_SUB_DONE;
 
@@ -369,12 +397,10 @@
 	struct proc *p;
 	unsigned i;
 	struct thread *td;
-	struct ksegrp *kg;
 
 	GIANT_REQUIRED;
 	p = &proc0;
 	td = &thread0;
-	kg = &ksegrp0;
 
 	/*
 	 * Initialize magic number.
@@ -382,14 +408,14 @@
 	p->p_magic = P_MAGIC;
 
 	/*
-	 * Initialize thread, process and ksegrp structures.
+	 * Initialize thread and process structures.
 	 */
 	procinit();	/* set up proc zone */
-	threadinit();	/* set up thead, upcall and KSEGRP zones */
+	threadinit();	/* set up UMA zones */
 
 	/*
 	 * Initialise scheduler resources.
-	 * Add scheduler specific parts to proc, ksegrp, thread as needed.
+	 * Add scheduler specific parts to proc, thread as needed.
 	 */
 	schedinit();	/* scheduler gets its house in order */
 	/*
@@ -426,8 +452,8 @@
 	STAILQ_INIT(&p->p_ktr);
 	p->p_nice = NZERO;
 	td->td_state = TDS_RUNNING;
-	kg->kg_pri_class = PRI_TIMESHARE;
-	kg->kg_user_pri = PUSER;
+	td->td_pri_class = PRI_TIMESHARE;
+	td->td_user_pri = PUSER;
 	td->td_priority = PVM;
 	td->td_base_pri = PUSER;
 	td->td_oncpu = 0;

==== //depot/projects/kmacy_sun4v/src/sys/kern/init_sysent.c#4 (text+ko) ====

@@ -2,8 +2,8 @@
  * System call switch table.
  *
  * DO NOT EDIT-- this file is automatically generated.
- * $FreeBSD: src/sys/kern/init_sysent.c,v 1.211 2006/03/23 08:48:37 davidxu Exp $
- * created from FreeBSD: src/sys/kern/syscalls.master,v 1.213 2006/03/23 08:46:41 davidxu Exp 
+ * $FreeBSD$
+ * created from FreeBSD: src/sys/kern/syscalls.master,v 1.215 2006/03/28 14:32:37 des Exp 
  */
 
 #include "opt_compat.h"
@@ -408,11 +408,11 @@
 	{ SYF_MPSAFE | AS(eaccess_args), (sy_call_t *)eaccess, AUE_EACCESS },	/* 376 = eaccess */
 	{ 0, (sy_call_t *)nosys, AUE_NULL },			/* 377 = afs_syscall */
 	{ AS(nmount_args), (sy_call_t *)nmount, AUE_NMOUNT },	/* 378 = nmount */
-	{ SYF_MPSAFE | 0, (sy_call_t *)kse_exit, AUE_NULL },	/* 379 = kse_exit */
-	{ SYF_MPSAFE | AS(kse_wakeup_args), (sy_call_t *)kse_wakeup, AUE_NULL },	/* 380 = kse_wakeup */
-	{ SYF_MPSAFE | AS(kse_create_args), (sy_call_t *)kse_create, AUE_NULL },	/* 381 = kse_create */
-	{ SYF_MPSAFE | AS(kse_thr_interrupt_args), (sy_call_t *)kse_thr_interrupt, AUE_NULL },	/* 382 = kse_thr_interrupt */
-	{ SYF_MPSAFE | AS(kse_release_args), (sy_call_t *)kse_release, AUE_NULL },	/* 383 = kse_release */
+	{ 0, (sy_call_t *)nosys, AUE_NULL },			/* 379 = kse_exit */
+	{ 0, (sy_call_t *)nosys, AUE_NULL },			/* 380 = kse_wakeup */
+	{ 0, (sy_call_t *)nosys, AUE_NULL },			/* 381 = kse_create */
+	{ 0, (sy_call_t *)nosys, AUE_NULL },			/* 382 = kse_thr_interrupt */
+	{ 0, (sy_call_t *)nosys, AUE_NULL },			/* 383 = kse_release */
 	{ SYF_MPSAFE | AS(__mac_get_proc_args), (sy_call_t *)__mac_get_proc, AUE_NULL },	/* 384 = __mac_get_proc */
 	{ SYF_MPSAFE | AS(__mac_set_proc_args), (sy_call_t *)__mac_set_proc, AUE_NULL },	/* 385 = __mac_set_proc */
 	{ SYF_MPSAFE | AS(__mac_get_fd_args), (sy_call_t *)__mac_get_fd, AUE_NULL },	/* 386 = __mac_get_fd */
@@ -469,7 +469,7 @@
 	{ SYF_MPSAFE | AS(extattr_list_fd_args), (sy_call_t *)extattr_list_fd, AUE_NULL },	/* 437 = extattr_list_fd */
 	{ SYF_MPSAFE | AS(extattr_list_file_args), (sy_call_t *)extattr_list_file, AUE_NULL },	/* 438 = extattr_list_file */
 	{ SYF_MPSAFE | AS(extattr_list_link_args), (sy_call_t *)extattr_list_link, AUE_NULL },	/* 439 = extattr_list_link */
-	{ SYF_MPSAFE | AS(kse_switchin_args), (sy_call_t *)kse_switchin, AUE_NULL },	/* 440 = kse_switchin */
+	{ 0, (sy_call_t *)nosys, AUE_NULL },			/* 440 = kse_switchin */
 	{ SYF_MPSAFE | AS(ksem_timedwait_args), (sy_call_t *)lkmressys, AUE_NULL },	/* 441 = ksem_timedwait */
 	{ SYF_MPSAFE | AS(thr_suspend_args), (sy_call_t *)thr_suspend, AUE_NULL },	/* 442 = thr_suspend */
 	{ SYF_MPSAFE | AS(thr_wake_args), (sy_call_t *)thr_wake, AUE_NULL },	/* 443 = thr_wake */

==== //depot/projects/kmacy_sun4v/src/sys/kern/kern_clock.c#4 (text+ko) ====

@@ -201,21 +201,17 @@
 	 * Run current process's virtual and profile time, as needed.
 	 */
 	mtx_lock_spin_flags(&sched_lock, MTX_QUIET);
-	if (p->p_flag & P_SA) {
-		/* XXXKSE What to do? */
-	} else {
-		pstats = p->p_stats;
-		if (usermode &&
-		    timevalisset(&pstats->p_timer[ITIMER_VIRTUAL].it_value) &&
-		    itimerdecr(&pstats->p_timer[ITIMER_VIRTUAL], tick) == 0) {
-			p->p_sflag |= PS_ALRMPEND;
-			td->td_flags |= TDF_ASTPENDING;
-		}
-		if (timevalisset(&pstats->p_timer[ITIMER_PROF].it_value) &&
-		    itimerdecr(&pstats->p_timer[ITIMER_PROF], tick) == 0) {
-			p->p_sflag |= PS_PROFPEND;
-			td->td_flags |= TDF_ASTPENDING;
-		}
+	pstats = p->p_stats;
+	if (usermode &&
+	    timevalisset(&pstats->p_timer[ITIMER_VIRTUAL].it_value) &&
+	    itimerdecr(&pstats->p_timer[ITIMER_VIRTUAL], tick) == 0) {
+		p->p_sflag |= PS_ALRMPEND;
+		td->td_flags |= TDF_ASTPENDING;
+	}
+	if (timevalisset(&pstats->p_timer[ITIMER_PROF].it_value) &&
+	    itimerdecr(&pstats->p_timer[ITIMER_PROF], tick) == 0) {
+		p->p_sflag |= PS_PROFPEND;
+		td->td_flags |= TDF_ASTPENDING;
 	}
 	mtx_unlock_spin_flags(&sched_lock, MTX_QUIET);
 
@@ -413,8 +409,6 @@
 		/*
 		 * Charge the time as appropriate.
 		 */
-		if (p->p_flag & P_SA)
-			thread_statclock(1);
 		td->td_uticks++;
 		if (p->p_nice > NZERO)
 			cp_time[CP_NICE]++;
@@ -438,8 +432,6 @@
 			td->td_iticks++;
 			cp_time[CP_INTR]++;
 		} else {
-			if (p->p_flag & P_SA)
-				thread_statclock(0);
 			td->td_pticks++;
 			td->td_sticks++;
 			if (td != PCPU_GET(idlethread))

==== //depot/projects/kmacy_sun4v/src/sys/kern/kern_fork.c#4 (text+ko) ====

@@ -205,7 +205,6 @@
 	struct filedesc *fd;
 	struct filedesc_to_leader *fdtol;
 	struct thread *td2;
-	struct ksegrp *kg2;
 	struct sigacts *newsigacts;
 	int error;
 
@@ -472,7 +471,6 @@
 	 * then copy the section that is copied directly from the parent.
 	 */
 	td2 = FIRST_THREAD_IN_PROC(p2);
-	kg2 = FIRST_KSEGRP_IN_PROC(p2);
 
 	/* Allocate and switch to an alternate kstack if specified. */
 	if (pages != 0)
@@ -485,15 +483,11 @@
 	    __rangeof(struct proc, p_startzero, p_endzero));
 	bzero(&td2->td_startzero,
 	    __rangeof(struct thread, td_startzero, td_endzero));
-	bzero(&kg2->kg_startzero,
-	    __rangeof(struct ksegrp, kg_startzero, kg_endzero));
 
 	bcopy(&p1->p_startcopy, &p2->p_startcopy,
 	    __rangeof(struct proc, p_startcopy, p_endcopy));
 	bcopy(&td->td_startcopy, &td2->td_startcopy,
 	    __rangeof(struct thread, td_startcopy, td_endcopy));
-	bcopy(&td->td_ksegrp->kg_startcopy, &kg2->kg_startcopy,
-	    __rangeof(struct ksegrp, kg_startcopy, kg_endcopy));
 
 	td2->td_sigstk = td->td_sigstk;
 	td2->td_sigmask = td->td_sigmask;

==== //depot/projects/kmacy_sun4v/src/sys/kern/kern_idle.c#4 (text+ko) ====

@@ -79,7 +79,7 @@
 		td = FIRST_THREAD_IN_PROC(p);
 		TD_SET_CAN_RUN(td);
 		atomic_set_int(&td->td_flags, TDF_IDLETD);
-		sched_class(td->td_ksegrp, PRI_IDLE);
+		sched_class(td, PRI_IDLE);
 		sched_prio(td, PRI_MAX_IDLE);
 		mtx_unlock_spin(&sched_lock);
 		PROC_UNLOCK(p);

==== //depot/projects/kmacy_sun4v/src/sys/kern/kern_intr.c#5 (text+ko) ====

@@ -296,7 +296,7 @@
 		panic("kthread_create() failed with %d", error);
 	td = FIRST_THREAD_IN_PROC(p);	/* XXXKSE */
 	mtx_lock_spin(&sched_lock);
-	td->td_ksegrp->kg_pri_class = PRI_ITHD;
+	td->td_pri_class = PRI_ITHD;
 	TD_SET_IWAIT(td);
 	mtx_unlock_spin(&sched_lock);
 	td->td_pflags |= TDP_ITHREAD;

==== //depot/projects/kmacy_sun4v/src/sys/kern/kern_mutex.c#7 (text+ko) ====


==== //depot/projects/kmacy_sun4v/src/sys/kern/kern_poll.c#4 (text+ko) ====

@@ -581,7 +581,7 @@
 	rtp.prio = RTP_PRIO_MAX;	/* lowest priority */
 	rtp.type = RTP_PRIO_IDLE;
 	mtx_lock_spin(&sched_lock);
-	rtp_to_pri(&rtp, td->td_ksegrp);
+	rtp_to_pri(&rtp, td);
 	mtx_unlock_spin(&sched_lock);
 
 	for (;;) {

==== //depot/projects/kmacy_sun4v/src/sys/kern/kern_proc.c#3 (text+ko) ====

@@ -142,9 +142,6 @@
 {
 	struct proc *p;
 	struct thread *td;
-#ifdef INVARIANTS
-	struct ksegrp *kg;
-#endif
 
 	/* INVARIANTS checks go here */
 	p = (struct proc *)mem;
@@ -152,10 +149,7 @@
 #ifdef INVARIANTS
 	KASSERT((p->p_numthreads == 1),
 	    ("bad number of threads in exiting process"));
-	KASSERT((p->p_numksegrps == 1), ("free proc with > 1 ksegrp"));
 	KASSERT((td != NULL), ("proc_dtor: bad thread pointer"));
-        kg = FIRST_KSEGRP_IN_PROC(p);
-	KASSERT((kg != NULL), ("proc_dtor: bad kg pointer"));
 	KASSERT(STAILQ_EMPTY(&p->p_ktr), ("proc_dtor: non-empty p_ktr"));
 #endif
 
@@ -178,17 +172,14 @@
 {
 	struct proc *p;
 	struct thread *td;
-	struct ksegrp *kg;
 
 	p = (struct proc *)mem;
 	p->p_sched = (struct p_sched *)&p[1];
 	td = thread_alloc();
-	kg = ksegrp_alloc();
 	bzero(&p->p_mtx, sizeof(struct mtx));
 	mtx_init(&p->p_mtx, "process lock", NULL, MTX_DEF | MTX_DUPOK);
 	p->p_stats = pstats_alloc();
-	proc_linkup(p, kg, td);
-	sched_newproc(p, kg, td);
+	proc_linkup(p, td);
 	return (0);
 }
 
@@ -204,7 +195,6 @@
 
 	p = (struct proc *)mem;
 	pstats_free(p->p_stats);
-	ksegrp_free(FIRST_KSEGRP_IN_PROC(p));
 	thread_free(FIRST_THREAD_IN_PROC(p));
 	mtx_destroy(&p->p_mtx);
 	if (p->p_ksi != NULL)
@@ -760,7 +750,6 @@
 static void
 fill_kinfo_thread(struct thread *td, struct kinfo_proc *kp)
 {
-	struct ksegrp *kg;
 	struct proc *p;
 
 	p = td->td_proc;
@@ -800,14 +789,6 @@
 		kp->ki_stat = SIDL;
 	}
 
-	kg = td->td_ksegrp;
-
-	/* things in the KSE GROUP */
-	kp->ki_estcpu = kg->kg_estcpu;
-	kp->ki_slptime = kg->kg_slptime;
-	kp->ki_pri.pri_user = kg->kg_user_pri;
-	kp->ki_pri.pri_class = kg->kg_pri_class;
-
 	/* Things in the thread */
 	kp->ki_wchan = td->td_wchan;
 	kp->ki_pri.pri_level = td->td_priority;
@@ -820,6 +801,10 @@
 	kp->ki_pcb = td->td_pcb;
 	kp->ki_kstack = (void *)td->td_kstack;
 	kp->ki_pctcpu = sched_pctcpu(td);
+	kp->ki_estcpu = td->td_estcpu;
+	kp->ki_slptime = td->td_slptime;
+	kp->ki_pri.pri_class = td->td_pri_class;
+	kp->ki_pri.pri_user = td->td_user_pri;
 
 	/* We can't get this anymore but ps etc never used it anyway. */
 	kp->ki_rqindex = 0;

==== //depot/projects/kmacy_sun4v/src/sys/kern/kern_resource.c#4 (text+ko) ====

@@ -292,7 +292,7 @@
 {
 	struct proc *curp;
 	struct proc *p;
-	struct ksegrp *kg;
+	struct thread *tdp;
 	struct rtprio rtp;
 	int cierror, error;
 
@@ -328,14 +328,14 @@
 		 * as leaving it zero.
 		 */
 		if (uap->pid == 0) {
-			pri_to_rtp(td->td_ksegrp, &rtp);
+			pri_to_rtp(td, &rtp);
 		} else {
 			struct rtprio rtp2;
 
 			rtp.type = RTP_PRIO_IDLE;
 			rtp.prio = RTP_PRIO_MAX;
-			FOREACH_KSEGRP_IN_PROC(p, kg) {
-				pri_to_rtp(kg, &rtp2);
+			FOREACH_THREAD_IN_PROC(p, tdp) {
+				pri_to_rtp(tdp, &rtp2);
 				if (rtp2.type <  rtp.type ||
 				    (rtp2.type == rtp.type &&
 				    rtp2.prio < rtp.prio)) {
@@ -378,18 +378,17 @@
 
 		/*
 		 * If we are setting our own priority, set just our
-		 * KSEGRP but if we are doing another process,
-		 * do all the groups on that process. If we
+		 * thread but if we are doing another process,
+		 * do all the threads on that process. If we
 		 * specify our own pid we do the latter.
 		 */
 		mtx_lock_spin(&sched_lock);
 		if (uap->pid == 0) {
-			error = rtp_to_pri(&rtp, td->td_ksegrp);
+			error = rtp_to_pri(&rtp, td);
 		} else {
-			FOREACH_KSEGRP_IN_PROC(p, kg) {
-				if ((error = rtp_to_pri(&rtp, kg)) != 0) {
+			FOREACH_THREAD_IN_PROC(p, td) {
+				if ((error = rtp_to_pri(&rtp, td)) != 0)
 					break;
-				}
 			}
 		}
 		mtx_unlock_spin(&sched_lock);
@@ -403,7 +402,7 @@
 }
 
 int
-rtp_to_pri(struct rtprio *rtp, struct ksegrp *kg)
+rtp_to_pri(struct rtprio *rtp, struct thread *td)
 {
 
 	mtx_assert(&sched_lock, MA_OWNED);
@@ -411,43 +410,42 @@
 		return (EINVAL);
 	switch (RTP_PRIO_BASE(rtp->type)) {
 	case RTP_PRIO_REALTIME:
-		kg->kg_user_pri = PRI_MIN_REALTIME + rtp->prio;
+		td->td_user_pri = PRI_MIN_REALTIME + rtp->prio;
 		break;
 	case RTP_PRIO_NORMAL:
-		kg->kg_user_pri = PRI_MIN_TIMESHARE + rtp->prio;
+		td->td_user_pri = PRI_MIN_TIMESHARE + rtp->prio;
 		break;
 	case RTP_PRIO_IDLE:
-		kg->kg_user_pri = PRI_MIN_IDLE + rtp->prio;
+		td->td_user_pri = PRI_MIN_IDLE + rtp->prio;
 		break;
 	default:
 		return (EINVAL);
 	}
-	sched_class(kg, rtp->type);
-	if (curthread->td_ksegrp == kg) {
-		sched_prio(curthread, kg->kg_user_pri); /* XXX dubious */
-	}
+	sched_class(td, rtp->type);	/* XXX fix */
+	if (curthread == td)
+		sched_prio(curthread, td->td_user_pri); /* XXX dubious */
 	return (0);
 }
 
 void
-pri_to_rtp(struct ksegrp *kg, struct rtprio *rtp)
+pri_to_rtp(struct thread *td, struct rtprio *rtp)
 {
 
 	mtx_assert(&sched_lock, MA_OWNED);
-	switch (PRI_BASE(kg->kg_pri_class)) {
+	switch (PRI_BASE(td->td_pri_class)) {
 	case PRI_REALTIME:
-		rtp->prio = kg->kg_user_pri - PRI_MIN_REALTIME;
+		rtp->prio = td->td_user_pri - PRI_MIN_REALTIME;
 		break;
 	case PRI_TIMESHARE:
-		rtp->prio = kg->kg_user_pri - PRI_MIN_TIMESHARE;
+		rtp->prio = td->td_user_pri - PRI_MIN_TIMESHARE;
 		break;
 	case PRI_IDLE:
-		rtp->prio = kg->kg_user_pri - PRI_MIN_IDLE;
+		rtp->prio = td->td_user_pri - PRI_MIN_IDLE;
 		break;
 	default:
 		break;
 	}
-	rtp->type = kg->kg_pri_class;
+	rtp->type = td->td_pri_class;
 }
 
 #if defined(COMPAT_43)

==== //depot/projects/kmacy_sun4v/src/sys/kern/kern_sig.c#6 (text+ko) ====

@@ -96,7 +96,6 @@
 static struct thread *sigtd(struct proc *p, int sig, int prop);
 static int	kern_sigtimedwait(struct thread *, sigset_t,
 			ksiginfo_t *, struct timespec *);
-static int	do_tdsignal(struct proc *, struct thread *, int, ksiginfo_t *);
 static void	sigqueue_start(void);
 
 static uma_zone_t	ksiginfo_zone = NULL;
@@ -570,7 +569,7 @@
 signotify(struct thread *td)
 {
 	struct proc *p;
-	sigset_t set, saved;
+	sigset_t set;
 
 	p = td->td_proc;
 
@@ -581,8 +580,6 @@
 	 * previously masked by all threads to our sigqueue.
 	 */
 	set = p->p_sigqueue.sq_signals;
-	if (p->p_flag & P_SA)
-		saved = p->p_sigqueue.sq_signals;
 	SIGSETNAND(set, td->td_sigmask);
 	if (! SIGISEMPTY(set))
 		sigqueue_move_set(&p->p_sigqueue, &td->td_sigqueue, &set);
@@ -591,13 +588,6 @@
 		td->td_flags |= TDF_NEEDSIGCHK | TDF_ASTPENDING;
 		mtx_unlock_spin(&sched_lock);
 	}
-	if ((p->p_flag & P_SA) && !(p->p_flag & P_SIGEVENT)) {
-		if (!SIGSETEQ(saved, p->p_sigqueue.sq_signals)) {
-			/* pending set changed */
-			p->p_flag |= P_SIGEVENT;
-			wakeup(&p->p_siglist);
-		}
-	}
 }
 
 int
@@ -749,11 +739,6 @@
 		if (ps->ps_sigact[_SIG_IDX(sig)] == SIG_IGN ||
 		    (sigprop(sig) & SA_IGNORE &&
 		     ps->ps_sigact[_SIG_IDX(sig)] == SIG_DFL)) {
-			if ((p->p_flag & P_SA) &&
-			     SIGISMEMBER(p->p_sigqueue.sq_signals, sig)) {
-				p->p_flag |= P_SIGEVENT;
-				wakeup(&p->p_siglist);
-			}
 			/* never to be seen again */
 			sigqueue_delete_proc(p, sig);
 			if (sig != SIGCONT)
@@ -1211,10 +1196,6 @@
 			continue;
 		if (!SIGISMEMBER(td->td_sigqueue.sq_signals, i)) {
 			if (SIGISMEMBER(p->p_sigqueue.sq_signals, i)) {
-				if (p->p_flag & P_SA) {
-					p->p_flag |= P_SIGEVENT;
-					wakeup(&p->p_siglist);
-				}
 				sigqueue_move(&p->p_sigqueue,
 					&td->td_sigqueue, i);
 			} else
@@ -1887,7 +1868,6 @@
 {
 	struct sigacts *ps;
 	struct proc *p;
-	int error;
 	int sig;
 	int code;
 
@@ -1896,23 +1876,7 @@
 	code = ksi->ksi_code;
 	KASSERT(_SIG_VALID(sig), ("invalid signal"));
 
-	if (td->td_pflags & TDP_SA) {
-		if (td->td_mailbox == NULL)
-			thread_user_enter(td);
-		PROC_LOCK(p);
-		SIGDELSET(td->td_sigmask, sig);
-		mtx_lock_spin(&sched_lock);
-		/*
-		 * Force scheduling an upcall, so UTS has chance to
-		 * process the signal before thread runs again in
-		 * userland.
-		 */
-		if (td->td_upcall)
-			td->td_upcall->ku_flags |= KUF_DOUPCALL;
-		mtx_unlock_spin(&sched_lock);
-	} else {
-		PROC_LOCK(p);
-	}
+	PROC_LOCK(p);

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



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