From 7cde6e34b7b6d52afd0b7cb965244ae2f67bb8b5 Mon Sep 17 00:00:00 2001 From: Mark Kettenis Date: Sat, 10 Nov 2007 00:22:30 +0000 Subject: For single-processor kernels, only match the CPU we're running on. --- sys/arch/sparc64/sparc64/cpu.c | 25 +++++++++++++++++++++++-- 1 file changed, 23 insertions(+), 2 deletions(-) (limited to 'sys') diff --git a/sys/arch/sparc64/sparc64/cpu.c b/sys/arch/sparc64/sparc64/cpu.c index eda5c156a5e..9743024c43a 100644 --- a/sys/arch/sparc64/sparc64/cpu.c +++ b/sys/arch/sparc64/sparc64/cpu.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cpu.c,v 1.29 2007/11/09 16:13:52 kettenis Exp $ */ +/* $OpenBSD: cpu.c,v 1.30 2007/11/10 00:22:29 kettenis Exp $ */ /* $NetBSD: cpu.c,v 1.13 2001/05/26 21:27:15 chs Exp $ */ /* @@ -174,8 +174,29 @@ cpu_match(parent, vcf, aux) { struct mainbus_attach_args *ma = aux; struct cfdata *cf = (struct cfdata *)vcf; +#ifndef MULTIPROCESSOR + int portid; +#endif + + if (strcmp(cf->cf_driver->cd_name, ma->ma_name) != 0) + return (0); + +#ifndef MULTIPROCESSOR + /* + * On singleprocessor kernels, only match the CPU we're + * running on. + */ + portid = getpropint(ma->ma_node, "portid", -1); + if (portid == -1) + portid = getpropint(ma->ma_node, "upa-portid", -1); + if (portid == -1) + return (0); + + if (portid != cpus->ci_upaid) + return (0); +#endif - return (strcmp(cf->cf_driver->cd_name, ma->ma_name) == 0); + return (1); } /* -- cgit v1.2.3