PERFORCE change 76133 for review
Robert Watson
rwatson at FreeBSD.org
Thu Apr 28 10:58:28 GMT 2005
http://perforce.freebsd.org/chv.cgi?CH=76133
Change 76133 by rwatson at rwatson_tislabs on 2005/04/28 10:57:52
top up integration of TrustedBSD MAC branch from TrustedBSD base:
primarily to pick up IPFILTER build cleanups.
Affected files ...
.. //depot/projects/trustedbsd/mac/etc/pam.d/xdm#8 integrate
.. //depot/projects/trustedbsd/mac/include/netdb.h#8 integrate
.. //depot/projects/trustedbsd/mac/lib/libbsnmp/modules/snmp_netgraph/snmp_netgraph.c#5 delete
.. //depot/projects/trustedbsd/mac/lib/libc/net/gethostbydns.c#13 integrate
.. //depot/projects/trustedbsd/mac/lib/libc/net/gethostbyht.c#5 integrate
.. //depot/projects/trustedbsd/mac/lib/libc/net/gethostnamadr.c#6 integrate
.. //depot/projects/trustedbsd/mac/lib/libc/net/getnetnamadr.c#4 integrate
.. //depot/projects/trustedbsd/mac/lib/libc/net/name6.c#16 integrate
.. //depot/projects/trustedbsd/mac/lib/libc/net/netdb_private.h#3 integrate
.. //depot/projects/trustedbsd/mac/lib/libthr/thread/thr_find_thread.c#4 delete
.. //depot/projects/trustedbsd/mac/lib/libthr/thread/thr_getschedparam.c#3 branch
.. //depot/projects/trustedbsd/mac/lib/libthr/thread/thr_mattr_kind_np.c#3 delete
.. //depot/projects/trustedbsd/mac/libexec/rtld-elf/i386/reloc.c#9 integrate
.. //depot/projects/trustedbsd/mac/share/mk/sys.mk#18 integrate
.. //depot/projects/trustedbsd/mac/sys/arm/xscale/i80321/iq31244_machdep.c#5 integrate
.. //depot/projects/trustedbsd/mac/sys/dev/hwpmc/hwpmc_amd.c#2 integrate
.. //depot/projects/trustedbsd/mac/sys/dev/hwpmc/hwpmc_mod.c#2 integrate
.. //depot/projects/trustedbsd/mac/sys/dev/hwpmc/hwpmc_piv.c#2 integrate
.. //depot/projects/trustedbsd/mac/sys/dev/hwpmc/hwpmc_ppro.c#2 integrate
.. //depot/projects/trustedbsd/mac/sys/dev/sound/usb/uaudio.c#7 integrate
.. //depot/projects/trustedbsd/mac/sys/dev/sound/usb/uaudio.h#3 integrate
.. //depot/projects/trustedbsd/mac/sys/dev/sound/usb/uaudio_pcm.c#8 integrate
.. //depot/projects/trustedbsd/mac/sys/dev/uart/uart_dev_z8530.c#4 integrate
.. //depot/projects/trustedbsd/mac/sys/hwpmc/hwpmc_amd.c#2 delete
.. //depot/projects/trustedbsd/mac/sys/hwpmc/hwpmc_intel.c#2 delete
.. //depot/projects/trustedbsd/mac/sys/hwpmc/hwpmc_mod.c#2 delete
.. //depot/projects/trustedbsd/mac/sys/hwpmc/hwpmc_pentium.c#2 delete
.. //depot/projects/trustedbsd/mac/sys/hwpmc/hwpmc_piv.c#2 delete
.. //depot/projects/trustedbsd/mac/sys/hwpmc/hwpmc_ppro.c#2 delete
.. //depot/projects/trustedbsd/mac/sys/i386/include/pmc_mdep.h#2 integrate
.. //depot/projects/trustedbsd/mac/sys/libkern/crc32.c#4 integrate
.. //depot/projects/trustedbsd/mac/sys/modules/hwpmc/Makefile#2 integrate
.. //depot/projects/trustedbsd/mac/sys/nfsclient/nfs_vfsops.c#37 integrate
.. //depot/projects/trustedbsd/mac/sys/sparc64/pci/apb.c#9 integrate
.. //depot/projects/trustedbsd/mac/sys/sys/libkern.h#16 integrate
.. //depot/projects/trustedbsd/mac/sys/sys/pmc.h#2 integrate
.. //depot/projects/trustedbsd/mac/sys/sys/systm.h#30 integrate
.. //depot/projects/trustedbsd/mac/usr.bin/make/Makefile#12 integrate
.. //depot/projects/trustedbsd/mac/usr.bin/make/directive_hash.c#1 branch
.. //depot/projects/trustedbsd/mac/usr.bin/make/directive_hash.h#1 branch
.. //depot/projects/trustedbsd/mac/usr.bin/make/parse.c#18 integrate
Differences ...
==== //depot/projects/trustedbsd/mac/etc/pam.d/xdm#8 (text+ko) ====
@@ -1,5 +1,5 @@
#
-# $FreeBSD: src/etc/pam.d/xdm,v 1.9 2004/02/20 21:59:51 des Exp $
+# $FreeBSD: src/etc/pam.d/xdm,v 1.10 2005/04/28 07:59:09 des Exp $
#
# PAM configuration for the "xdm" service
#
@@ -16,7 +16,7 @@
# session
#session required pam_ssh.so want_agent
-session required pam_permit.so
+session required pam_lastlog.so no_fail
# password
password required pam_deny.so
==== //depot/projects/trustedbsd/mac/include/netdb.h#8 (text+ko) ====
@@ -55,7 +55,7 @@
/*
* @(#)netdb.h 8.1 (Berkeley) 6/2/93
* From: Id: netdb.h,v 8.9 1996/11/19 08:39:29 vixie Exp $
- * $FreeBSD: src/include/netdb.h,v 1.34 2005/02/14 11:33:11 phantom Exp $
+ * $FreeBSD: src/include/netdb.h,v 1.35 2005/04/27 19:12:56 ume Exp $
*/
#ifndef _NETDB_H_
@@ -257,18 +257,6 @@
/* DO NOT USE THESE, THEY ARE SUBJECT TO CHANGE AND ARE NOT PORTABLE!!! */
int * __h_error(void);
-void _sethosthtent(int);
-void _endhosthtent(void);
-void _sethostdnsent(int);
-void _endhostdnsent(void);
-void _setnethtent(int);
-void _endnethtent(void);
-void _setnetdnsent(int);
-void _endnetdnsent(void);
-struct hostent * _gethostbynisname(const char *, int);
-struct hostent * _gethostbynisaddr(const char *, int, int);
-void _map_v4v6_address(const char *, char *);
-void _map_v4v6_hostent(struct hostent *, char **, char **);
__END_DECLS
#endif /* !_NETDB_H_ */
==== //depot/projects/trustedbsd/mac/lib/libc/net/gethostbydns.c#13 (text+ko) ====
@@ -58,7 +58,7 @@
static char fromrcsid[] = "From: Id: gethnamaddr.c,v 8.23 1998/04/07 04:59:46 vixie Exp $";
#endif /* LIBC_SCCS and not lint */
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/lib/libc/net/gethostbydns.c,v 1.49 2005/04/25 17:36:28 ume Exp $");
+__FBSDID("$FreeBSD: src/lib/libc/net/gethostbydns.c,v 1.50 2005/04/27 19:12:57 ume Exp $");
#include <sys/types.h>
#include <sys/param.h>
@@ -79,6 +79,7 @@
#include <stdarg.h>
#include <nsswitch.h>
+#include "netdb_private.h"
#include "res_config.h"
#define SPRINTF(x) ((size_t)sprintf x)
==== //depot/projects/trustedbsd/mac/lib/libc/net/gethostbyht.c#5 (text+ko) ====
@@ -55,7 +55,7 @@
static char sccsid[] = "@(#)gethostnamadr.c 8.1 (Berkeley) 6/4/93";
#endif /* LIBC_SCCS and not lint */
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/lib/libc/net/gethostbyht.c,v 1.17 2005/01/03 11:07:45 sobomax Exp $");
+__FBSDID("$FreeBSD: src/lib/libc/net/gethostbyht.c,v 1.18 2005/04/27 19:12:57 ume Exp $");
#include <sys/param.h>
#include <sys/socket.h>
@@ -69,6 +69,7 @@
#include <nsswitch.h>
#include <arpa/nameser.h> /* XXX */
#include <resolv.h> /* XXX */
+#include "netdb_private.h"
#define MAXALIASES 35
==== //depot/projects/trustedbsd/mac/lib/libc/net/gethostnamadr.c#6 (text+ko) ====
@@ -24,7 +24,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/lib/libc/net/gethostnamadr.c,v 1.23 2005/04/25 17:36:28 ume Exp $");
+__FBSDID("$FreeBSD: src/lib/libc/net/gethostnamadr.c,v 1.24 2005/04/27 19:12:57 ume Exp $");
#include "namespace.h"
#include <sys/param.h>
@@ -41,6 +41,7 @@
#include <arpa/nameser.h> /* XXX hack for _res */
#include <resolv.h> /* XXX hack for _res */
#include "un-namespace.h"
+#include "netdb_private.h"
extern int _ht_gethostbyname(void *, void *, va_list);
extern int _dns_gethostbyname(void *, void *, va_list);
==== //depot/projects/trustedbsd/mac/lib/libc/net/getnetnamadr.c#4 (text+ko) ====
@@ -24,7 +24,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/lib/libc/net/getnetnamadr.c,v 1.17 2003/04/24 18:05:48 nectar Exp $");
+__FBSDID("$FreeBSD: src/lib/libc/net/getnetnamadr.c,v 1.18 2005/04/27 19:12:57 ume Exp $");
#include "namespace.h"
#include <sys/param.h>
@@ -38,6 +38,7 @@
#include <stdarg.h>
#include <nsswitch.h>
#include "un-namespace.h"
+#include "netdb_private.h"
extern int _ht_getnetbyname(void *, void *, va_list);
extern int _dns_getnetbyname(void *, void *, va_list);
==== //depot/projects/trustedbsd/mac/lib/libc/net/name6.c#16 (text+ko) ====
@@ -88,7 +88,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/lib/libc/net/name6.c,v 1.45 2005/04/19 12:28:17 ume Exp $");
+__FBSDID("$FreeBSD: src/lib/libc/net/name6.c,v 1.46 2005/04/27 19:12:57 ume Exp $");
#include "namespace.h"
#if defined(YP) || defined(ICMPNL)
@@ -120,6 +120,7 @@
#include <nsswitch.h>
#include <unistd.h>
#include "un-namespace.h"
+#include "netdb_private.h"
#ifndef _PATH_HOSTS
#define _PATH_HOSTS "/etc/hosts"
==== //depot/projects/trustedbsd/mac/lib/libc/net/netdb_private.h#3 (text+ko) ====
@@ -22,7 +22,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
- * $FreeBSD: src/lib/libc/net/netdb_private.h,v 1.4 2005/04/19 14:41:13 ume Exp $
+ * $FreeBSD: src/lib/libc/net/netdb_private.h,v 1.5 2005/04/27 19:12:57 ume Exp $
*/
#ifndef _NETDB_PRIVATE_H_
@@ -79,6 +79,18 @@
struct protodata *__protodata_init(void);
struct servdata *__servdata_init(void);
+void _endhostdnsent(void);
+void _endhosthtent(void);
+void _endnetdnsent(void);
+void _endnethtent(void);
+struct hostent *_gethostbynisaddr(const char *, int, int);
+struct hostent *_gethostbynisname(const char *, int);
+void _map_v4v6_address(const char *, char *);
+void _map_v4v6_hostent(struct hostent *, char **, char **);
+void _sethostdnsent(int);
+void _sethosthtent(int);
+void _setnetdnsent(int);
+void _setnethtent(int);
void endprotoent_r(struct protoent_data *);
void endservent_r(struct servent_data *);
int getprotobyname_r(const char *, struct protoent *, struct protoent_data *);
==== //depot/projects/trustedbsd/mac/libexec/rtld-elf/i386/reloc.c#9 (text+ko) ====
@@ -22,7 +22,7 @@
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
- * $FreeBSD: src/libexec/rtld-elf/i386/reloc.c,v 1.16 2005/04/26 20:38:44 peter Exp $
+ * $FreeBSD: src/libexec/rtld-elf/i386/reloc.c,v 1.17 2005/04/27 13:17:23 davidxu Exp $
*/
/*
@@ -336,7 +336,7 @@
* use.
*/
tls_static_space = tls_last_offset + RTLD_STATIC_TLS_EXTRA;
- tls = alloca_tls(objs, NULL, 2*sizeof(Elf_Addr), sizeof(Elf_Addr));
+ tls = allocate_tls(objs, NULL, 2*sizeof(Elf_Addr), sizeof(Elf_Addr));
error = i386_set_gsbase(tls);
if (error < 0) {
memset(&ldt, 0, sizeof(ldt));
==== //depot/projects/trustedbsd/mac/share/mk/sys.mk#18 (text+ko) ====
@@ -1,5 +1,5 @@
# from: @(#)sys.mk 8.2 (Berkeley) 3/21/94
-# $FreeBSD: src/share/mk/sys.mk,v 1.83 2004/12/23 08:51:50 ru Exp $
+# $FreeBSD: src/share/mk/sys.mk,v 1.84 2005/04/27 14:13:55 scottl Exp $
unix ?= We run FreeBSD, not UNIX.
.FreeBSD ?= true
@@ -265,6 +265,11 @@
.include "${__MAKE_CONF}"
.endif
+# XXX Hack until IPFILTER is buildable again.
+.if !defined(WANT_IPFILTER)
+NO_IPFILTER=
+.endif
+
# Default executable format
# XXX hint for bsd.port.mk
OBJFORMAT?= elf
==== //depot/projects/trustedbsd/mac/sys/arm/xscale/i80321/iq31244_machdep.c#5 (text+ko) ====
@@ -48,7 +48,7 @@
#include "opt_msgbuf.h"
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/arm/xscale/i80321/iq31244_machdep.c,v 1.10 2005/04/07 22:04:18 cognet Exp $");
+__FBSDID("$FreeBSD: src/sys/arm/xscale/i80321/iq31244_machdep.c,v 1.11 2005/04/27 13:29:54 cognet Exp $");
#define _ARM32_BUS_DMA_PRIVATE
#include <sys/param.h>
@@ -356,13 +356,6 @@
pmap_map_chunk(l1pagetable, undstack.pv_va, undstack.pv_pa,
UND_STACK_SIZE * PAGE_SIZE, VM_PROT_READ|VM_PROT_WRITE,
PTE_CACHE);
- if (freemem_after + KSTACK_PAGES * PAGE_SIZE < afterkern) {
- alloc_afterkern(kernelstack.pv_va, kernelstack.pv_pa,
- KSTACK_PAGES * PAGE_SIZE);
- } else
- pmap_map_chunk(l1pagetable, kernelstack.pv_va,
- kernelstack.pv_pa, KSTACK_PAGES * PAGE_SIZE,
- VM_PROT_READ|VM_PROT_WRITE, PTE_CACHE);
if (freemem_after + MSGBUF_SIZE < afterkern) {
alloc_afterkern(msgbufpv.pv_va, msgbufpv.pv_pa,
IRQ_STACK_SIZE * PAGE_SIZE);
==== //depot/projects/trustedbsd/mac/sys/dev/hwpmc/hwpmc_amd.c#2 (text+ko) ====
@@ -26,7 +26,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/dev/hwpmc/hwpmc_amd.c,v 1.3 2005/04/27 05:51:13 jkoshy Exp $");
+__FBSDID("$FreeBSD: src/sys/dev/hwpmc/hwpmc_amd.c,v 1.4 2005/04/28 08:13:18 jkoshy Exp $");
/* Support for the AMD K7 and later processors */
@@ -443,6 +443,8 @@
{
struct pmc_hw *phw;
+ PMCDBG(MDP,CFG,1, "cpu=%d ri=%d pm=%p", cpu, ri, pm);
+
KASSERT(cpu >= 0 && cpu < mp_ncpus,
("[amd,%d] illegal CPU value %d", __LINE__, cpu));
KASSERT(ri >= 0 && ri < AMD_NPMCS,
@@ -451,7 +453,8 @@
phw = pmc_pcpu[cpu]->pc_hwpmcs[ri];
KASSERT(pm == NULL || phw->phw_pmc == NULL,
- ("[amd,%d] hwpmc not unconfigured before re-config", __LINE__));
+ ("[amd,%d] pm=%p phw->pm=%p hwpmc not unconfigured",
+ __LINE__, pm, phw->phw_pmc));
phw->phw_pmc = pm;
return 0;
@@ -463,12 +466,17 @@
*/
static int
-amd_switch_in(struct pmc_cpu *pc)
+amd_switch_in(struct pmc_cpu *pc, struct pmc_process *pp)
{
(void) pc;
- /* enable the RDPMC instruction */
- load_cr4(rcr4() | CR4_PCE);
+ PMCDBG(MDP,SWI,1, "pc=%p pp=%p enable-msr=%d", pc, pp,
+ (pp->pp_flags & PMC_FLAG_ENABLE_MSR_ACCESS) != 0);
+
+ /* enable the RDPMC instruction if needed */
+ if (pp->pp_flags & PMC_FLAG_ENABLE_MSR_ACCESS)
+ load_cr4(rcr4() | CR4_PCE);
+
return 0;
}
@@ -478,12 +486,17 @@
*/
static int
-amd_switch_out(struct pmc_cpu *pc)
+amd_switch_out(struct pmc_cpu *pc, struct pmc_process *pp)
{
(void) pc;
+ (void) pp; /* can be NULL */
+
+ PMCDBG(MDP,SWO,1, "pc=%p pp=%p enable-msr=%d", pc, pp, pp ?
+ (pp->pp_flags & PMC_FLAG_ENABLE_MSR_ACCESS) == 1 : 0);
- /* disallow RDPMC instruction */
+ /* always turn off the RDPMC instruction */
load_cr4(rcr4() & ~CR4_PCE);
+
return 0;
}
@@ -818,7 +831,7 @@
KASSERT(ri >= 0 && ri < AMD_NPMCS,
("[amd,%d] ri %d out of range", __LINE__, ri));
- *msr = amd_pmcdesc[ri].pm_perfctr;
+ *msr = amd_pmcdesc[ri].pm_perfctr - AMD_PMC_PERFCTR_0;
return 0;
}
==== //depot/projects/trustedbsd/mac/sys/dev/hwpmc/hwpmc_mod.c#2 (text+ko) ====
@@ -26,7 +26,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/dev/hwpmc/hwpmc_mod.c,v 1.5 2005/04/27 05:51:13 jkoshy Exp $");
+__FBSDID("$FreeBSD: src/sys/dev/hwpmc/hwpmc_mod.c,v 1.6 2005/04/28 08:13:18 jkoshy Exp $");
#include <sys/param.h>
#include <sys/eventhandler.h>
@@ -739,8 +739,13 @@
atomic_store_rel_ptr(&pp->pp_pmcs[ri].pp_pmc, pm);
+ if (pm->pm_owner->po_owner == pp->pp_proc)
+ pp->pp_flags |= PMC_FLAG_ENABLE_MSR_ACCESS;
+
pp->pp_refcnt++;
+ PMCDBG(PRC,TLK,2, "enable-msr %d",
+ (pp->pp_flags & PMC_FLAG_ENABLE_MSR_ACCESS) != 0);
}
/*
@@ -774,6 +779,9 @@
pp->pp_pmcs[ri].pp_pmc = NULL;
pp->pp_pmcs[ri].pp_pmcval = (pmc_value_t) 0;
+ if (pm->pm_owner->po_owner == pp->pp_proc)
+ pp->pp_flags &= ~PMC_FLAG_ENABLE_MSR_ACCESS;
+
pp->pp_refcnt--;
/* Remove the target process from the PMC structure */
@@ -784,7 +792,8 @@
KASSERT(ptgt != NULL, ("[pmc,%d] process %p (pp: %p) not found "
"in pmc %p", __LINE__, pp->pp_proc, pp, pm));
- PMCDBG(PRC,TUL,4, "unlink ptgt=%p", ptgt);
+ PMCDBG(PRC,TUL,4, "unlink ptgt=%p, enable-msr=%d", ptgt,
+ (pp->pp_flags & PMC_FLAG_ENABLE_MSR_ACCESS) != 0);
LIST_REMOVE(ptgt, pt_next);
FREE(ptgt, M_PMC);
@@ -1159,10 +1168,10 @@
"process-exit proc=%p pmc-process=%p", p, pp);
/*
- * This process could the target of some PMCs.
- * Such PMCs will thus be running on currently
- * executing CPU at this point in the code
- * since we've disallowed context switches.
+ * The exiting process could the target of
+ * some PMCs which will be running on
+ * currently executing CPU.
+ *
* We need to turn these PMCs off like we
* would do at context switch OUT time.
*/
@@ -1219,6 +1228,14 @@
atomic_subtract_rel_32(&pm->pm_runcount,1);
(void) md->pmd_config_pmc(cpu, ri, NULL);
}
+
+ /*
+ * Inform the MD layer of this pseudo "context switch
+ * out"
+ */
+
+ (void) md->pmd_switch_out(pmc_pcpu[cpu], pp);
+
critical_exit(); /* ok to be pre-empted now */
/*
@@ -1475,7 +1492,7 @@
* switch-in actions.
*/
- (void) (*md->pmd_switch_in)(pc);
+ (void) (*md->pmd_switch_in)(pc, pp);
critical_exit();
@@ -1614,7 +1631,7 @@
* switch out functions.
*/
- (void) (*md->pmd_switch_out)(pc);
+ (void) (*md->pmd_switch_out)(pc, pp);
critical_exit();
==== //depot/projects/trustedbsd/mac/sys/dev/hwpmc/hwpmc_piv.c#2 (text+ko) ====
@@ -25,7 +25,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/dev/hwpmc/hwpmc_piv.c,v 1.4 2005/04/27 05:51:13 jkoshy Exp $");
+__FBSDID("$FreeBSD: src/sys/dev/hwpmc/hwpmc_piv.c,v 1.5 2005/04/28 08:13:18 jkoshy Exp $");
#include <sys/param.h>
#include <sys/lock.h>
@@ -578,11 +578,19 @@
*/
static int
-p4_switch_in(struct pmc_cpu *pc)
+p4_switch_in(struct pmc_cpu *pc, struct pmc_process *pp)
{
(void) pc;
+
+ PMCDBG(MDP,SWI,1, "pc=%p pp=%p enable-msr=%d", pc, pp,
+ (pp->pp_flags & PMC_FLAG_ENABLE_MSR_ACCESS) != 0);
+
/* enable the RDPMC instruction */
- load_cr4(rcr4() | CR4_PCE);
+ if (pp->pp_flags & PMC_FLAG_ENABLE_MSR_ACCESS)
+ load_cr4(rcr4() | CR4_PCE);
+
+ PMCDBG(MDP,SWI,2, "cr4=0x%x", rcr4());
+
return 0;
}
@@ -591,11 +599,18 @@
*/
static int
-p4_switch_out(struct pmc_cpu *pc)
+p4_switch_out(struct pmc_cpu *pc, struct pmc_process *pp)
{
(void) pc;
- /* disallow RDPMC instruction */
+ (void) pp; /* can be null */
+
+ PMCDBG(MDP,SWO,1, "pc=%p pp=%p", pc, pp);
+
+ /* always disallow the RDPMC instruction */
load_cr4(rcr4() & ~CR4_PCE);
+
+ PMCDBG(MDP,SWO,2, "cr4=0x%x", rcr4());
+
return 0;
}
@@ -1419,7 +1434,10 @@
KASSERT(ri >= 0 && ri < P4_NPMCS,
("[p4,%d] ri %d out of range", __LINE__, ri));
- *msr = p4_pmcdesc[ri].pm_pmc_msr;
+ *msr = p4_pmcdesc[ri].pm_pmc_msr - P4_PERFCTR_MSR_FIRST;
+
+ PMCDBG(MDP,OPS, 1, "ri=%d getmsr=0x%x", ri, *msr);
+
return 0;
}
==== //depot/projects/trustedbsd/mac/sys/dev/hwpmc/hwpmc_ppro.c#2 (text+ko) ====
@@ -25,7 +25,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/dev/hwpmc/hwpmc_ppro.c,v 1.3 2005/04/27 05:51:13 jkoshy Exp $");
+__FBSDID("$FreeBSD: src/sys/dev/hwpmc/hwpmc_ppro.c,v 1.4 2005/04/28 08:13:18 jkoshy Exp $");
#include <sys/param.h>
#include <sys/lock.h>
@@ -332,16 +332,25 @@
}
static int
-p6_switch_in(struct pmc_cpu *pc)
+p6_switch_in(struct pmc_cpu *pc, struct pmc_process *pp)
{
(void) pc;
+
+ /* allow the RDPMC instruction if needed */
+ if (pp->pp_flags & PMC_FLAG_ENABLE_MSR_ACCESS)
+ load_cr4(rcr4() | CR4_PCE);
return 0;
}
static int
-p6_switch_out(struct pmc_cpu *pc)
+p6_switch_out(struct pmc_cpu *pc, struct pmc_process *pp)
{
(void) pc;
+ (void) pp; /* can be NULL */
+
+ /* always turn off the RDPMC instruction */
+ load_cr4(rcr4() & ~CR4_PCE);
+
return 0;
}
==== //depot/projects/trustedbsd/mac/sys/dev/sound/usb/uaudio.c#7 (text+ko) ====
@@ -1,5 +1,5 @@
/* $NetBSD: uaudio.c,v 1.91 2004/11/05 17:46:14 kent Exp $ */
-/* $FreeBSD: src/sys/dev/sound/usb/uaudio.c,v 1.13 2005/01/06 01:43:22 imp Exp $ */
+/* $FreeBSD: src/sys/dev/sound/usb/uaudio.c,v 1.14 2005/04/27 17:16:27 julian Exp $ */
/*-
* Copyright (c) 1999 The NetBSD Foundation, Inc.
@@ -72,6 +72,7 @@
#include <sys/poll.h>
#if defined(__FreeBSD__)
#include <sys/sysctl.h>
+#include <sys/sbuf.h>
#endif
#if defined(__NetBSD__) || defined(__OpenBSD__)
@@ -83,6 +84,7 @@
#elif defined(__FreeBSD__)
#include <dev/sound/pcm/sound.h> /* XXXXX */
#include <dev/sound/chip.h>
+#include "feeder_if.h"
#endif
#include <dev/usb/usb.h>
@@ -234,6 +236,10 @@
int sc_nctls; /* # of mixer controls */
device_ptr_t sc_audiodev;
char sc_dying;
+#if defined(__FreeBSD__)
+ struct sbuf uaudio_sndstat;
+ int uaudio_sndstat_flag;
+#endif
};
struct terminal_list {
@@ -444,6 +450,7 @@
#elif defined(__FreeBSD__)
Static int audio_attach_mi(device_t);
Static int uaudio_init_params(struct uaudio_softc * sc, struct chan *ch, int mode);
+static int uaudio_sndstat_prepare_pcm(struct sbuf *s, device_t dev, int verbose);
/* for NetBSD compatibirity */
#define AUMODE_PLAY 0x01
@@ -642,6 +649,9 @@
{
USB_DETACH_START(uaudio, sc);
+ sbuf_delete(&(sc->uaudio_sndstat));
+ sc->uaudio_sndstat_flag = 0;
+
sc->sc_dying = 1;
#if 0 /* XXX */
@@ -1894,6 +1904,7 @@
const char *format_str;
asid = (const void *)(buf + offs);
+
if (asid->bDescriptorType != UDESC_CS_INTERFACE ||
asid->bDescriptorSubtype != AS_GENERAL)
return (USBD_INVAL);
@@ -2068,6 +2079,28 @@
printf("Hz\n");
}
#endif
+#if defined(__FreeBSD__)
+ if (sc->uaudio_sndstat_flag != 0) {
+ sbuf_printf(&(sc->uaudio_sndstat), "\n\t");
+ sbuf_printf(&(sc->uaudio_sndstat),
+ "mode %d:(%s) %dch, %d/%dbit, %s,",
+ id->bAlternateSetting,
+ dir == UE_DIR_IN ? "input" : "output",
+ chan, prec, asf1d->bSubFrameSize * 8, format_str);
+ if (asf1d->bSamFreqType == UA_SAMP_CONTNUOUS) {
+ sbuf_printf(&(sc->uaudio_sndstat), " %d-%dHz",
+ UA_SAMP_LO(asf1d), UA_SAMP_HI(asf1d));
+ } else {
+ int r;
+ sbuf_printf(&(sc->uaudio_sndstat),
+ " %d", UA_GETSAMP(asf1d, 0));
+ for (r = 1; r < asf1d->bSamFreqType; r++)
+ sbuf_printf(&(sc->uaudio_sndstat),
+ ",%d", UA_GETSAMP(asf1d, r));
+ sbuf_printf(&(sc->uaudio_sndstat), "Hz");
+ }
+ }
+#endif
ai.alt = id->bAlternateSetting;
ai.encoding = enc;
ai.attributes = sed->bmAttributes;
@@ -2106,6 +2139,11 @@
if (id == NULL)
return (USBD_INVAL);
+#if defined(__FreeBSD__)
+ sc->uaudio_sndstat_flag = 0;
+ if (sbuf_new(&(sc->uaudio_sndstat), NULL, 4096, SBUF_AUTOEXTEND) != NULL)
+ sc->uaudio_sndstat_flag = 1;
+#endif
/* Loop through all the alternate settings. */
while (offs <= size) {
DPRINTFN(2, ("uaudio_identify: interface=%d offset=%d\n",
@@ -2132,6 +2170,9 @@
if (id == NULL)
break;
}
+#if defined(__FreeBSD__)
+ sbuf_finish(&(sc->uaudio_sndstat));
+#endif
if (offs > size)
return (USBD_INVAL);
DPRINTF(("uaudio_identify_as: %d alts available\n", sc->sc_nalts));
@@ -4171,6 +4212,118 @@
return (1 << mc->slctrtype[mc->minval - 1]);
}
+static int
+uaudio_sndstat_prepare_pcm(struct sbuf *s, device_t dev, int verbose)
+{
+ struct snddev_info *d;
+ struct snddev_channel *sce;
+ struct pcm_channel *c;
+ struct pcm_feeder *f;
+ int pc, rc, vc;
+ device_t pa_dev = device_get_parent(dev);
+ struct uaudio_softc *sc = device_get_softc(pa_dev);
+
+ if (verbose < 1)
+ return 0;
+
+ d = device_get_softc(dev);
+ if (!d)
+ return ENXIO;
+
+ snd_mtxlock(d->lock);
+ if (SLIST_EMPTY(&d->channels)) {
+ sbuf_printf(s, " (mixer only)");
+ snd_mtxunlock(d->lock);
+ return 0;
+ }
+ pc = rc = vc = 0;
+ SLIST_FOREACH(sce, &d->channels, link) {
+ c = sce->channel;
+ if (c->direction == PCMDIR_PLAY) {
+ if (c->flags & CHN_F_VIRTUAL)
+ vc++;
+ else
+ pc++;
+ } else
+ rc++;
+ }
+ sbuf_printf(s, " (%dp/%dr/%dv channels%s%s)",
+ d->playcount, d->reccount, d->vchancount,
+ (d->flags & SD_F_SIMPLEX)? "" : " duplex",
+#ifdef USING_DEVFS
+ (device_get_unit(dev) == snd_unit)? " default" : ""
+#else
+ ""
+#endif
+ );
+
+ if (sc->uaudio_sndstat_flag != 0) {
+ sbuf_cat(s, sbuf_data(&(sc->uaudio_sndstat)));
+ }
+
+ if (verbose <= 1) {
+ snd_mtxunlock(d->lock);
+ return 0;
+ }
+
+ SLIST_FOREACH(sce, &d->channels, link) {
+ c = sce->channel;
+ sbuf_printf(s, "\n\t");
+
+ /* it would be better to indent child channels */
+ sbuf_printf(s, "%s[%s]: ", c->parentchannel? c->parentchannel->name : "", c->name);
+ sbuf_printf(s, "spd %d", c->speed);
+ if (c->speed != sndbuf_getspd(c->bufhard))
+ sbuf_printf(s, "/%d", sndbuf_getspd(c->bufhard));
+ sbuf_printf(s, ", fmt 0x%08x", c->format);
+ if (c->format != sndbuf_getfmt(c->bufhard))
+ sbuf_printf(s, "/0x%08x", sndbuf_getfmt(c->bufhard));
+ sbuf_printf(s, ", flags 0x%08x, 0x%08x", c->flags, c->feederflags);
+ if (c->pid != -1)
+ sbuf_printf(s, ", pid %d", c->pid);
+ sbuf_printf(s, "\n\t");
+
+ if (c->bufhard != NULL && c->bufsoft != NULL) {
+ sbuf_printf(s, "interrupts %d, ", c->interrupts);
+ if (c->direction == PCMDIR_REC)
+ sbuf_printf(s, "overruns %d, hfree %d, sfree %d",
+ c->xruns, sndbuf_getfree(c->bufhard), sndbuf_getfree(c->bufsoft));
+ else
+ sbuf_printf(s, "underruns %d, ready %d",
+ c->xruns, sndbuf_getready(c->bufsoft));
+ sbuf_printf(s, "\n\t");
+ }
+
+ sbuf_printf(s, "{%s}", (c->direction == PCMDIR_REC)? "hardware" : "userland");
+ sbuf_printf(s, " -> ");
+ f = c->feeder;
+ while (f->source != NULL)
+ f = f->source;
+ while (f != NULL) {
+ sbuf_printf(s, "%s", f->class->name);
+ if (f->desc->type == FEEDER_FMT)
+ sbuf_printf(s, "(0x%08x -> 0x%08x)", f->desc->in, f->desc->out);
+ if (f->desc->type == FEEDER_RATE)
+ sbuf_printf(s, "(%d -> %d)", FEEDER_GET(f, FEEDRATE_SRC), FEEDER_GET(f, FEEDRATE_DST));
+ if (f->desc->type == FEEDER_ROOT || f->desc->type == FEEDER_MIXER)
+ sbuf_printf(s, "(0x%08x)", f->desc->out);
+ sbuf_printf(s, " -> ");
+ f = f->parent;
+ }
+ sbuf_printf(s, "{%s}", (c->direction == PCMDIR_REC)? "userland" : "hardware");
+ }
+ snd_mtxunlock(d->lock);
+
+ return 0;
+}
+
+void
+uaudio_sndstat_register(device_t dev)
+{
+ struct snddev_info *d = device_get_softc(dev);
+ sndstat_register(dev, d->status, uaudio_sndstat_prepare_pcm);
+}
+
Static int
audio_attach_mi(device_t dev)
{
==== //depot/projects/trustedbsd/mac/sys/dev/sound/usb/uaudio.h#3 (text+ko) ====
@@ -1,4 +1,4 @@
-/* $FreeBSD: src/sys/dev/sound/usb/uaudio.h,v 1.5 2005/01/06 01:43:22 imp Exp $ */
+/* $FreeBSD: src/sys/dev/sound/usb/uaudio.h,v 1.6 2005/04/27 17:16:27 julian Exp $ */
/*-
* Copyright (c) 2000-2002 Hiroyuki Aizu <aizu at navi.org>
@@ -50,3 +50,4 @@
u_int32_t uaudio_query_mix_info(device_t dev);
u_int32_t uaudio_query_recsrc_info(device_t dev);
void uaudio_query_formats(device_t dev, u_int32_t *pfmt, u_int32_t *rfmt);
+void uaudio_sndstat_register(device_t dev);
==== //depot/projects/trustedbsd/mac/sys/dev/sound/usb/uaudio_pcm.c#8 (text+ko) ====
@@ -1,4 +1,4 @@
-/* $FreeBSD: src/sys/dev/sound/usb/uaudio_pcm.c,v 1.14 2005/04/17 16:26:08 matk Exp $ */
+/* $FreeBSD: src/sys/dev/sound/usb/uaudio_pcm.c,v 1.15 2005/04/27 17:16:27 julian Exp $ */
/*-
* Copyright (c) 2000-2002 Hiroyuki Aizu <aizu at navi.org>
@@ -344,6 +344,9 @@
return(ENXIO);
}
+ sndstat_unregister(dev);
+ uaudio_sndstat_register(dev);
+
pcm_addchan(dev, PCMDIR_PLAY, &ua_chan_class, ua);
#ifndef NO_RECORDING
pcm_addchan(dev, PCMDIR_REC, &ua_chan_class, ua);
==== //depot/projects/trustedbsd/mac/sys/dev/uart/uart_dev_z8530.c#4 (text+ko) ====
@@ -25,7 +25,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/dev/uart/uart_dev_z8530.c,v 1.11 2005/01/30 09:00:50 marcel Exp $");
+__FBSDID("$FreeBSD: src/sys/dev/uart/uart_dev_z8530.c,v 1.12 2005/04/27 21:57:51 marcel Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -213,7 +213,7 @@
z8530_putc(struct uart_bas *bas, int c)
{
- while (!(uart_getmreg(bas, RR_BES) & BES_TXE))
+ while (!(uart_getreg(bas, REG_CTRL) & BES_TXE))
;
uart_setreg(bas, REG_DATA, c);
uart_barrier(bas);
@@ -223,7 +223,7 @@
z8530_poll(struct uart_bas *bas)
{
- if (!(uart_getmreg(bas, RR_BES) & BES_RXA))
+ if (!(uart_getreg(bas, REG_CTRL) & BES_RXA))
return (-1);
return (uart_getreg(bas, REG_DATA));
}
@@ -232,7 +232,7 @@
z8530_getc(struct uart_bas *bas)
{
- while (!(uart_getmreg(bas, RR_BES) & BES_RXA))
+ while (!(uart_getreg(bas, REG_CTRL) & BES_RXA))
;
return (uart_getreg(bas, REG_DATA));
}
==== //depot/projects/trustedbsd/mac/sys/i386/include/pmc_mdep.h#2 (text+ko) ====
@@ -23,7 +23,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
- * $FreeBSD: src/sys/i386/include/pmc_mdep.h,v 1.2 2005/04/20 20:22:33 marcel Exp $
+ * $FreeBSD: src/sys/i386/include/pmc_mdep.h,v 1.3 2005/04/28 08:13:19 jkoshy Exp $
*/
/* Machine dependent interfaces */
@@ -123,6 +123,9 @@
#define P4_PERFCTR_MASK 0xFFFFFFFFFFLL /* 40 bits */
+#define P4_CCCR_MSR_FIRST 0x360 /* MSR_BPU_CCCR0 */
+#define P4_PERFCTR_MSR_FIRST 0x300 /* MSR_BPU_COUNTER0 */
+
/* Intel PPro, Celeron, P-II, P-III, Pentium-M PMCS */
#define P6_NPMCS 3 /* 1 TSC + 2 PMCs */
==== //depot/projects/trustedbsd/mac/sys/libkern/crc32.c#4 (text+ko) ====
@@ -43,7 +43,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/libkern/crc32.c,v 1.3 2005/01/07 00:24:32 imp Exp $");
+__FBSDID("$FreeBSD: src/sys/libkern/crc32.c,v 1.5 2005/04/28 05:50:18 marcel Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -94,18 +94,21 @@
0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d
};
-uint32_t
-crc32(const void *buf, size_t size)
-{
- const uint8_t *p;
- uint32_t crc;
-
- p = buf;
- crc = ~0U;
-
- while (size--)
- crc = crc32_tab[(crc ^ *p++) & 0xFF] ^ (crc >> 8);
-
- return crc ^ ~0U;
-}
-
+/*
+ * A function that calculates the CRC-32 based on the table above is
+ * given below for documentation purposes. An equivalent implementation
+ * of this function that's actually used in the kernel can be found
+ * in sys/libkern.h, where it can be inlined.
+ *
+ * uint32_t
+ * crc32(const void *buf, size_t size)
+ * {
+ * const uint8_t *p = buf;
+ * uint32_t crc;
+ *
+ * crc = ~0U;
+ * while (size--)
+ * crc = crc32_tab[(crc ^ *p++) & 0xFF] ^ (crc >> 8);
+ * return crc ^ ~0U;
+ * }
+ */
==== //depot/projects/trustedbsd/mac/sys/modules/hwpmc/Makefile#2 (text+ko) ====
@@ -1,8 +1,8 @@
#
-# $FreeBSD: src/sys/modules/hwpmc/Makefile,v 1.1 2005/04/19 04:01:24 jkoshy Exp $
+# $FreeBSD: src/sys/modules/hwpmc/Makefile,v 1.2 2005/04/28 00:53:45 jkoshy Exp $
#
-.PATH: ${.CURDIR}/../../hwpmc
+.PATH: ${.CURDIR}/../../dev/hwpmc
KMOD= hwpmc
==== //depot/projects/trustedbsd/mac/sys/nfsclient/nfs_vfsops.c#37 (text+ko) ====
@@ -33,7 +33,7 @@
*/
#include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/sys/nfsclient/nfs_vfsops.c,v 1.172 2005/03/24 07:37:22 jeff Exp $");
+__FBSDID("$FreeBSD: src/sys/nfsclient/nfs_vfsops.c,v 1.173 2005/04/27 14:46:02 des Exp $");
#include "opt_bootp.h"
#include "opt_nfsroot.h"
@@ -513,9 +513,7 @@
int maxio;
s = splnet();
- if (vfs_getopt(mp->mnt_optnew, "ro", NULL, NULL))
- mp->mnt_flag &= ~MNT_RDONLY;
- else
+ if (vfs_getopt(mp->mnt_optnew, "ro", NULL, NULL) == 0)
mp->mnt_flag |= MNT_RDONLY;
/*
* Silently clear NFSMNT_NOCONN if it's a TCP mount, it makes
==== //depot/projects/trustedbsd/mac/sys/sparc64/pci/apb.c#9 (text+ko) ====
@@ -30,7 +30,7 @@
*
>>> TRUNCATED FOR MAIL (1000 lines) <<<
To Unsubscribe: send mail to majordomo at trustedbsd.org
with "unsubscribe trustedbsd-cvs" in the body of the message
More information about the trustedbsd-cvs
mailing list