Commit d017aafb authored by Anton Blanchard's avatar Anton Blanchard

ppc64: Update the fake pci read code to handle a return of all 1s.

parent 40d78f02
...@@ -78,14 +78,12 @@ rtas_read_config_##size(struct device_node *dn, int offset, type val) { \ ...@@ -78,14 +78,12 @@ rtas_read_config_##size(struct device_node *dn, int offset, type val) { \
\ \
if (dn == NULL) { \ if (dn == NULL) { \
ret = -2; \ ret = -2; \
} else if (dn->status) { \
ret = -1; \
} else { \ } else { \
addr = (dn->busno << 16) | (dn->devfn << 8) | offset; \ addr = (dn->busno << 16) | (dn->devfn << 8) | offset; \
buid = dn->phb->buid; \ buid = dn->phb->buid; \
if (buid) { \ if (buid) { \
ret = rtas_call(ibm_read_pci_config, 4, 2, &returnval, addr, buid >> 32, buid & 0xffffffff, nbytes); \ ret = rtas_call(ibm_read_pci_config, 4, 2, &returnval, addr, buid >> 32, buid & 0xffffffff, nbytes); \
if (ret < 0) \ if (ret < 0|| (returnval == 0xffffffff)) \
ret = rtas_fake_read(dn, offset, nbytes, &returnval); \ ret = rtas_fake_read(dn, offset, nbytes, &returnval); \
} else { \ } else { \
ret = rtas_call(read_pci_config, 2, 2, &returnval, addr, nbytes); \ ret = rtas_call(read_pci_config, 2, 2, &returnval, addr, nbytes); \
...@@ -111,8 +109,6 @@ rtas_write_config_##size(struct device_node *dn, int offset, type val) { \ ...@@ -111,8 +109,6 @@ rtas_write_config_##size(struct device_node *dn, int offset, type val) { \
\ \
if (dn == NULL) { \ if (dn == NULL) { \
ret = -2; \ ret = -2; \
} else if (dn->status) { \
ret = -1; \
} else { \ } else { \
buid = dn->phb->buid; \ buid = dn->phb->buid; \
addr = (dn->busno << 16) | (dn->devfn << 8) | offset; \ addr = (dn->busno << 16) | (dn->devfn << 8) | offset; \
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment