Workaround for ICH6M: ports implemented mask 0 is no longer an error.
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@22959 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
3c374980b5
commit
27367cc308
@ -24,6 +24,7 @@ AHCIController::AHCIController(device_node_handle node, pci_device_info *device)
|
||||
, fCommandSlotCount(0)
|
||||
, fPortCountMax(0)
|
||||
, fPortCountAvail(0)
|
||||
, fPortImplementedMask(0)
|
||||
, fIRQ(0)
|
||||
, fInstanceCheck(-1)
|
||||
{
|
||||
@ -126,13 +127,15 @@ AHCIController::Init()
|
||||
|
||||
fCommandSlotCount = 1 + ((fRegs->cap >> CAP_NCS_SHIFT) & CAP_NCS_MASK);
|
||||
fPortCountMax = 1 + ((fRegs->cap >> CAP_NP_SHIFT) & CAP_NP_MASK);
|
||||
fPortCountAvail = count_bits_set(fRegs->pi);
|
||||
|
||||
if (fRegs->pi == 0) {
|
||||
TRACE("controller doesn't implement any ports\n");
|
||||
goto err;
|
||||
fPortImplementedMask = fRegs->pi;
|
||||
if (fPortImplementedMask == 0) {
|
||||
fPortImplementedMask = 0xffffffff >> (32 - fPortCountMax);
|
||||
TRACE("ports-implemented mask is zero, using 0x%lx instead.\n", fPortImplementedMask);
|
||||
}
|
||||
|
||||
fPortCountAvail = count_bits_set(fPortImplementedMask);
|
||||
|
||||
TRACE("cap: Interface Speed Support: generation %lu\n", (fRegs->cap >> CAP_ISS_SHIFT) & CAP_ISS_MASK);
|
||||
TRACE("cap: Number of Command Slots: %d (raw %#lx)\n", fCommandSlotCount, (fRegs->cap >> CAP_NCS_SHIFT) & CAP_NCS_MASK);
|
||||
TRACE("cap: Number of Ports: %d (raw %#lx)\n", fPortCountMax, (fRegs->cap >> CAP_NP_SHIFT) & CAP_NP_MASK);
|
||||
@ -152,7 +155,7 @@ AHCIController::Init()
|
||||
|
||||
TRACE("cap: Supports AHCI mode only: %s\n", (fRegs->cap & CAP_SAM) ? "yes" : "no");
|
||||
TRACE("ghc: AHCI Enable: %s\n", (fRegs->ghc & GHC_AE) ? "yes" : "no");
|
||||
TRACE("Ports Implemented Mask: %#08lx\n", fRegs->pi);
|
||||
TRACE("Ports Implemented Mask: %#08lx\n", fPortImplementedMask);
|
||||
TRACE("Number of Available Ports: %d\n", fPortCountAvail);
|
||||
TRACE("AHCI Version %lu.%lu\n", fRegs->vs >> 16, fRegs->vs & 0xff);
|
||||
TRACE("Interrupt %u\n", fIRQ);
|
||||
@ -164,7 +167,7 @@ AHCIController::Init()
|
||||
}
|
||||
|
||||
for (int i = 0; i <= fPortCountMax; i++) {
|
||||
if (fRegs->pi & (1 << i)) {
|
||||
if (fPortImplementedMask & (1 << i)) {
|
||||
fPort[i] = new (std::nothrow)AHCIPort(this, i);
|
||||
if (!fPort[i]) {
|
||||
TRACE("out of memory creating port %d", i);
|
||||
@ -271,7 +274,7 @@ int32
|
||||
AHCIController::Interrupt(void *data)
|
||||
{
|
||||
AHCIController *self = (AHCIController *)data;
|
||||
uint32 int_stat = self->fRegs->is & self->fRegs->pi;
|
||||
uint32 int_stat = self->fRegs->is & self->fPortImplementedMask;
|
||||
if (int_stat == 0)
|
||||
return B_UNHANDLED_INTERRUPT;
|
||||
|
||||
|
@ -48,6 +48,7 @@ private:
|
||||
int fCommandSlotCount;
|
||||
int fPortCountMax;
|
||||
int fPortCountAvail;
|
||||
uint32 fPortImplementedMask;
|
||||
uint8 fIRQ;
|
||||
AHCIPort * fPort[32];
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user