Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 250094
b: refs/heads/master
c: 24a4742
h: refs/heads/master
v: v3
  • Loading branch information
Alex Williamson authored and Jesse Barnes committed May 21, 2011
1 parent 1c5102a commit 2951124
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 9 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 9f728f53dd70396f3183d2f0861022259471824b
refs/heads/master: 24a4742f0be6226eb0106fbb17caf4d711d1ad43
12 changes: 7 additions & 5 deletions trunk/drivers/pci/pci.c
Original file line number Diff line number Diff line change
Expand Up @@ -830,7 +830,7 @@ static int pci_save_pcie_state(struct pci_dev *dev)
dev_err(&dev->dev, "buffer not found in %s\n", __func__);
return -ENOMEM;
}
cap = (u16 *)&save_state->data[0];
cap = (u16 *)&save_state->cap.data[0];

pci_read_config_word(dev, pos + PCI_EXP_FLAGS, &flags);

Expand Down Expand Up @@ -863,7 +863,7 @@ static void pci_restore_pcie_state(struct pci_dev *dev)
pos = pci_find_capability(dev, PCI_CAP_ID_EXP);
if (!save_state || pos <= 0)
return;
cap = (u16 *)&save_state->data[0];
cap = (u16 *)&save_state->cap.data[0];

pci_read_config_word(dev, pos + PCI_EXP_FLAGS, &flags);

Expand Down Expand Up @@ -899,7 +899,8 @@ static int pci_save_pcix_state(struct pci_dev *dev)
return -ENOMEM;
}

pci_read_config_word(dev, pos + PCI_X_CMD, (u16 *)save_state->data);
pci_read_config_word(dev, pos + PCI_X_CMD,
(u16 *)save_state->cap.data);

return 0;
}
Expand All @@ -914,7 +915,7 @@ static void pci_restore_pcix_state(struct pci_dev *dev)
pos = pci_find_capability(dev, PCI_CAP_ID_PCIX);
if (!save_state || pos <= 0)
return;
cap = (u16 *)&save_state->data[0];
cap = (u16 *)&save_state->cap.data[0];

pci_write_config_word(dev, pos + PCI_X_CMD, cap[i++]);
}
Expand Down Expand Up @@ -1771,7 +1772,8 @@ static int pci_add_cap_save_buffer(
if (!save_state)
return -ENOMEM;

save_state->cap_nr = cap;
save_state->cap.cap_nr = cap;
save_state->cap.size = size;
pci_add_saved_cap(dev, save_state);

return 0;
Expand Down
11 changes: 8 additions & 3 deletions trunk/include/linux/pci.h
Original file line number Diff line number Diff line change
Expand Up @@ -214,12 +214,17 @@ enum pci_bus_speed {
PCI_SPEED_UNKNOWN = 0xff,
};

struct pci_cap_saved_state {
struct hlist_node next;
struct pci_cap_saved_data {
char cap_nr;
unsigned int size;
u32 data[0];
};

struct pci_cap_saved_state {
struct hlist_node next;
struct pci_cap_saved_data cap;
};

struct pcie_link_state;
struct pci_vpd;
struct pci_sriov;
Expand Down Expand Up @@ -366,7 +371,7 @@ static inline struct pci_cap_saved_state *pci_find_saved_cap(
struct hlist_node *pos;

hlist_for_each_entry(tmp, pos, &pci_dev->saved_cap_space, next) {
if (tmp->cap_nr == cap)
if (tmp->cap.cap_nr == cap)
return tmp;
}
return NULL;
Expand Down

0 comments on commit 2951124

Please sign in to comment.