call cpu_topology_set() with adjustments for 970MP CPUs
This commit is contained in:
parent
194b0d85bc
commit
e4a15eebdd
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: cpu.c,v 1.67 2018/05/17 19:08:51 macallan Exp $ */
|
/* $NetBSD: cpu.c,v 1.68 2019/12/13 23:01:41 macallan Exp $ */
|
||||||
|
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 2001 Tsubai Masanari.
|
* Copyright (c) 2001 Tsubai Masanari.
|
||||||
@ -33,7 +33,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
__KERNEL_RCSID(0, "$NetBSD: cpu.c,v 1.67 2018/05/17 19:08:51 macallan Exp $");
|
__KERNEL_RCSID(0, "$NetBSD: cpu.c,v 1.68 2019/12/13 23:01:41 macallan Exp $");
|
||||||
|
|
||||||
#include "opt_ppcparam.h"
|
#include "opt_ppcparam.h"
|
||||||
#include "opt_multiprocessor.h"
|
#include "opt_multiprocessor.h"
|
||||||
@ -45,6 +45,7 @@ __KERNEL_RCSID(0, "$NetBSD: cpu.c,v 1.67 2018/05/17 19:08:51 macallan Exp $");
|
|||||||
#include <sys/device.h>
|
#include <sys/device.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/lwp.h>
|
#include <sys/lwp.h>
|
||||||
|
#include <sys/cpu.h>
|
||||||
|
|
||||||
#include <dev/ofw/openfirm.h>
|
#include <dev/ofw/openfirm.h>
|
||||||
#include <powerpc/oea/hid.h>
|
#include <powerpc/oea/hid.h>
|
||||||
@ -159,12 +160,23 @@ cpuattach(device_t parent, device_t self, void *aux)
|
|||||||
{
|
{
|
||||||
struct cpu_info *ci;
|
struct cpu_info *ci;
|
||||||
struct confargs *ca = aux;
|
struct confargs *ca = aux;
|
||||||
int id = ca->ca_reg[0];
|
int id = ca->ca_reg[0], vers, package, core;
|
||||||
|
|
||||||
ci = cpu_attach_common(self, id);
|
ci = cpu_attach_common(self, id);
|
||||||
if (ci == NULL)
|
if (ci == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
package = id;
|
||||||
|
core = 0;
|
||||||
|
|
||||||
|
vers = (mfpvr() >> 16) & 0xffff;
|
||||||
|
|
||||||
|
if (vers == IBM970MP) {
|
||||||
|
core = package & 1;
|
||||||
|
package >>= 1;
|
||||||
|
}
|
||||||
|
cpu_topology_set(ci, package, core, 0);
|
||||||
|
|
||||||
if (ci->ci_khz == 0) {
|
if (ci->ci_khz == 0) {
|
||||||
cpu_OFgetspeed(self, ci);
|
cpu_OFgetspeed(self, ci);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user