Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 5 Jul 2004 17:32:55 -0400 
From:      Alex Hoff <ahoff@sandvine.com>
To:        "'freebsd-current@freebsd.org'" <freebsd-current@freebsd.org>
Subject:   FreeBSD 5.2.1 hangs on boot with acpi disabled
Message-ID:  <FE045D4D9F7AED4CBFF1B3B813C8533703FFC33E@mail.sandvine.com>

next in thread | raw e-mail | index | archive | help
A fellow colleague posted a message on the same topic (see
http://lists.freebsd.org/pipermail/freebsd-current/2004-March/023045.html),
and I have spent some time investigating the same problem. In response to
the original post, yes the machine boots fine with acpi enabled. 

I have traced the hang to one particular function : isa_probe_children. In
this function it attempts a bus probe, then attempts to retrieve a pointer
array to all the device's children. The children's device names (when
booting with no acpi) are shown below: 
Note the names are retrieved using this function device_get_nameunit(child)

isa_probe_children = 0 orm0
isa_probe_children = 1 pmtimer0
isa_probe_children = 2 adv0
.....
isa_probe_children = 24 vt0
and 
isa_probe_children = 25 (null)
...
isa_probe_children = 42 (null)
When acpi IS enabled, 25-42 disappear.

The function continues through the first 2 for loops and goes to the for
loop under this line printf("isa_probe_children: probing PnP devices\n");
Now devices 0-25 satisfy the following condition
if (!TAILQ_FIRST(&idev->id_configs))
			continue;
and the rest of the devices try have resources assigned to them. This is
where the problem occurs, in that the pointers and requested resources by
the children are all incorrect (ie negative memory requests). Thus the
allocate memory function loops forever. A quick "hackish" work around was to
skip over the devices that requested to have resources assigned to them. 

Now my question is, how and where do these devices (specifically on isa0)
get their children populated from? I cant seem to find that section of code.
Moving forward, I would imagine there is a bug in that code which is
incorrectly populating the isa0 device struct, and thus causing the hang. 
The machine itself is a SuperMicro X5DP8 with dual Xeon 2800s with a total
of 4GB of memory. We have some other supermicro motherboards (such as
X5DPR-8G2) which do not have the same problem.

Thanks



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