mirror of
https://github.com/freebsd/freebsd-src.git
synced 2024-12-03 19:08:58 +00:00
Use new helper functions to set PCIe max read request size.
This commit is contained in:
parent
24d6a5ed27
commit
2622a559a7
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=203529
@ -230,20 +230,10 @@ static int
|
||||
siis_resume(device_t dev)
|
||||
{
|
||||
struct siis_controller *ctlr = device_get_softc(dev);
|
||||
int cap;
|
||||
uint16_t val;
|
||||
|
||||
/* Set PCIe max read request size to at least 1024 bytes */
|
||||
if (pci_find_extcap(dev, PCIY_EXPRESS, &cap) == 0) {
|
||||
val = pci_read_config(dev,
|
||||
cap + PCIR_EXPRESS_DEVICE_CTL, 2);
|
||||
if ((val & PCIM_EXP_CTL_MAX_READ_REQUEST) < 0x3000) {
|
||||
val &= ~PCIM_EXP_CTL_MAX_READ_REQUEST;
|
||||
val |= 0x3000;
|
||||
pci_write_config(dev,
|
||||
cap + PCIR_EXPRESS_DEVICE_CTL, val, 2);
|
||||
}
|
||||
}
|
||||
if (pci_get_max_read_req(dev) < 1024)
|
||||
pci_set_max_read_req(dev, 1024);
|
||||
/* Put controller into reset state. */
|
||||
ctlr->gctl |= SIIS_GCTL_GRESET;
|
||||
ATA_OUTL(ctlr->r_gmem, SIIS_GCTL, ctlr->gctl);
|
||||
|
Loading…
Reference in New Issue
Block a user