|
@@ -781,38 +781,40 @@ extern const struct psb_ops cdv_chip_ops;
|
|
|
extern int drm_idle_check_interval;
|
|
|
|
|
|
/* Utilities */
|
|
|
-static inline u32 MRST_MSG_READ32(uint port, uint offset)
|
|
|
+static inline u32 MRST_MSG_READ32(int domain, uint port, uint offset)
|
|
|
{
|
|
|
int mcr = (0xD0<<24) | (port << 16) | (offset << 8);
|
|
|
uint32_t ret_val = 0;
|
|
|
- struct pci_dev *pci_root = pci_get_bus_and_slot(0, 0);
|
|
|
+ struct pci_dev *pci_root = pci_get_domain_bus_and_slot(domain, 0, 0);
|
|
|
pci_write_config_dword(pci_root, 0xD0, mcr);
|
|
|
pci_read_config_dword(pci_root, 0xD4, &ret_val);
|
|
|
pci_dev_put(pci_root);
|
|
|
return ret_val;
|
|
|
}
|
|
|
-static inline void MRST_MSG_WRITE32(uint port, uint offset, u32 value)
|
|
|
+static inline void MRST_MSG_WRITE32(int domain, uint port, uint offset,
|
|
|
+ u32 value)
|
|
|
{
|
|
|
int mcr = (0xE0<<24) | (port << 16) | (offset << 8) | 0xF0;
|
|
|
- struct pci_dev *pci_root = pci_get_bus_and_slot(0, 0);
|
|
|
+ struct pci_dev *pci_root = pci_get_domain_bus_and_slot(domain, 0, 0);
|
|
|
pci_write_config_dword(pci_root, 0xD4, value);
|
|
|
pci_write_config_dword(pci_root, 0xD0, mcr);
|
|
|
pci_dev_put(pci_root);
|
|
|
}
|
|
|
-static inline u32 MDFLD_MSG_READ32(uint port, uint offset)
|
|
|
+static inline u32 MDFLD_MSG_READ32(int domain, uint port, uint offset)
|
|
|
{
|
|
|
int mcr = (0x10<<24) | (port << 16) | (offset << 8);
|
|
|
uint32_t ret_val = 0;
|
|
|
- struct pci_dev *pci_root = pci_get_bus_and_slot(0, 0);
|
|
|
+ struct pci_dev *pci_root = pci_get_domain_bus_and_slot(domain, 0, 0);
|
|
|
pci_write_config_dword(pci_root, 0xD0, mcr);
|
|
|
pci_read_config_dword(pci_root, 0xD4, &ret_val);
|
|
|
pci_dev_put(pci_root);
|
|
|
return ret_val;
|
|
|
}
|
|
|
-static inline void MDFLD_MSG_WRITE32(uint port, uint offset, u32 value)
|
|
|
+static inline void MDFLD_MSG_WRITE32(int domain, uint port, uint offset,
|
|
|
+ u32 value)
|
|
|
{
|
|
|
int mcr = (0x11<<24) | (port << 16) | (offset << 8) | 0xF0;
|
|
|
- struct pci_dev *pci_root = pci_get_bus_and_slot(0, 0);
|
|
|
+ struct pci_dev *pci_root = pci_get_domain_bus_and_slot(domain, 0, 0);
|
|
|
pci_write_config_dword(pci_root, 0xD4, value);
|
|
|
pci_write_config_dword(pci_root, 0xD0, mcr);
|
|
|
pci_dev_put(pci_root);
|