Commit 2427d174 authored by Sergio Paracuellos's avatar Sergio Paracuellos Committed by Greg Kroah-Hartman

staging: mt7621-pci: factor out mt7621_pci_get_cfgaddr function

To get config address the same pattern is repeated in some functions
along the code. Factor out a new mt7621_pci_get_cfgaddr for calculate
it and use it in convenient places. Adjust types to match to u32 where
is neccesary.
Signed-off-by: default avatarSergio Paracuellos <sergio.paracuellos@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent fc4afdfe
...@@ -177,19 +177,26 @@ static int pcie_link_status = 0; ...@@ -177,19 +177,26 @@ static int pcie_link_status = 0;
#define PCI_ACCESS_WRITE_2 4 #define PCI_ACCESS_WRITE_2 4
#define PCI_ACCESS_WRITE_4 5 #define PCI_ACCESS_WRITE_4 5
static inline u32 mt7621_pci_get_cfgaddr(unsigned int bus, unsigned int slot,
unsigned int func, unsigned int where)
{
return (((where & 0xF00) >> 8) << 24) | (bus << 16) | (slot << 11) |
(func << 8) | (where & 0xfc) | 0x80000000;
}
static int config_access(unsigned char access_type, struct pci_bus *bus, static int config_access(unsigned char access_type, struct pci_bus *bus,
unsigned int devfn, unsigned int where, u32 *data) unsigned int devfn, unsigned int where, u32 *data)
{ {
unsigned int slot = PCI_SLOT(devfn); unsigned int slot = PCI_SLOT(devfn);
u8 func = PCI_FUNC(devfn); u8 func = PCI_FUNC(devfn);
uint32_t address_reg, data_reg; u32 address_reg, data_reg;
unsigned int address; unsigned int address;
address_reg = RALINK_PCI_CONFIG_ADDR; address_reg = RALINK_PCI_CONFIG_ADDR;
data_reg = RALINK_PCI_CONFIG_DATA_VIRTUAL_REG; data_reg = RALINK_PCI_CONFIG_DATA_VIRTUAL_REG;
address = (((where&0xF00)>>8)<<24) |(bus->number << 16) | (slot << 11) | address = mt7621_pci_get_cfgaddr(bus->number, slot, func, where);
(func << 8) | (where & 0xfc) | 0x80000000;
MV_WRITE(address_reg, address); MV_WRITE(address_reg, address);
switch (access_type) { switch (access_type) {
...@@ -305,11 +312,11 @@ static struct pci_controller mt7621_controller = { ...@@ -305,11 +312,11 @@ static struct pci_controller mt7621_controller = {
static void static void
read_config(unsigned long bus, unsigned long dev, unsigned long func, unsigned long reg, unsigned long *val) read_config(unsigned long bus, unsigned long dev, unsigned long func, unsigned long reg, unsigned long *val)
{ {
unsigned int address_reg, data_reg, address; u32 address_reg, data_reg, address;
address_reg = RALINK_PCI_CONFIG_ADDR; address_reg = RALINK_PCI_CONFIG_ADDR;
data_reg = RALINK_PCI_CONFIG_DATA_VIRTUAL_REG; data_reg = RALINK_PCI_CONFIG_DATA_VIRTUAL_REG;
address = (((reg & 0xF00)>>8)<<24) | (bus << 16) | (dev << 11) | (func << 8) | (reg & 0xfc) | 0x80000000 ; address = mt7621_pci_get_cfgaddr(bus, dev, func, reg);
MV_WRITE(address_reg, address); MV_WRITE(address_reg, address);
MV_READ(data_reg, val); MV_READ(data_reg, val);
return; return;
...@@ -318,11 +325,11 @@ read_config(unsigned long bus, unsigned long dev, unsigned long func, unsigned l ...@@ -318,11 +325,11 @@ read_config(unsigned long bus, unsigned long dev, unsigned long func, unsigned l
static void static void
write_config(unsigned long bus, unsigned long dev, unsigned long func, unsigned long reg, unsigned long val) write_config(unsigned long bus, unsigned long dev, unsigned long func, unsigned long reg, unsigned long val)
{ {
unsigned int address_reg, data_reg, address; u32 address_reg, data_reg, address;
address_reg = RALINK_PCI_CONFIG_ADDR; address_reg = RALINK_PCI_CONFIG_ADDR;
data_reg = RALINK_PCI_CONFIG_DATA_VIRTUAL_REG; data_reg = RALINK_PCI_CONFIG_DATA_VIRTUAL_REG;
address = (((reg & 0xF00)>>8)<<24) | (bus << 16) | (dev << 11) | (func << 8) | (reg & 0xfc) | 0x80000000 ; address = mt7621_pci_get_cfgaddr(bus, dev, func, reg);
MV_WRITE(address_reg, address); MV_WRITE(address_reg, address);
MV_WRITE(data_reg, val); MV_WRITE(data_reg, val);
return; return;
......
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