mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-17 05:45:20 +00:00
PCI: export __pci_read_base()
Export __pci_read_base() so it can be used by whole PCI subsystem. Signed-off-by: Yu Zhao <yu.zhao@intel.com> Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
This commit is contained in:
parent
bc5f5a8277
commit
0b400c7ed4
@ -162,6 +162,15 @@ struct pci_slot_attribute {
|
|||||||
};
|
};
|
||||||
#define to_pci_slot_attr(s) container_of(s, struct pci_slot_attribute, attr)
|
#define to_pci_slot_attr(s) container_of(s, struct pci_slot_attribute, attr)
|
||||||
|
|
||||||
|
enum pci_bar_type {
|
||||||
|
pci_bar_unknown, /* Standard PCI BAR probe */
|
||||||
|
pci_bar_io, /* An io port BAR */
|
||||||
|
pci_bar_mem32, /* A 32-bit memory BAR */
|
||||||
|
pci_bar_mem64, /* A 64-bit memory BAR */
|
||||||
|
};
|
||||||
|
|
||||||
|
extern int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type,
|
||||||
|
struct resource *res, unsigned int reg);
|
||||||
extern void pci_enable_ari(struct pci_dev *dev);
|
extern void pci_enable_ari(struct pci_dev *dev);
|
||||||
/**
|
/**
|
||||||
* pci_ari_enabled - query ARI forwarding status
|
* pci_ari_enabled - query ARI forwarding status
|
||||||
|
@ -135,13 +135,6 @@ static u64 pci_size(u64 base, u64 maxbase, u64 mask)
|
|||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
enum pci_bar_type {
|
|
||||||
pci_bar_unknown, /* Standard PCI BAR probe */
|
|
||||||
pci_bar_io, /* An io port BAR */
|
|
||||||
pci_bar_mem32, /* A 32-bit memory BAR */
|
|
||||||
pci_bar_mem64, /* A 64-bit memory BAR */
|
|
||||||
};
|
|
||||||
|
|
||||||
static inline enum pci_bar_type decode_bar(struct resource *res, u32 bar)
|
static inline enum pci_bar_type decode_bar(struct resource *res, u32 bar)
|
||||||
{
|
{
|
||||||
if ((bar & PCI_BASE_ADDRESS_SPACE) == PCI_BASE_ADDRESS_SPACE_IO) {
|
if ((bar & PCI_BASE_ADDRESS_SPACE) == PCI_BASE_ADDRESS_SPACE_IO) {
|
||||||
@ -156,11 +149,16 @@ static inline enum pci_bar_type decode_bar(struct resource *res, u32 bar)
|
|||||||
return pci_bar_mem32;
|
return pci_bar_mem32;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* If the type is not unknown, we assume that the lowest bit is 'enable'.
|
* pci_read_base - read a PCI BAR
|
||||||
* Returns 1 if the BAR was 64-bit and 0 if it was 32-bit.
|
* @dev: the PCI device
|
||||||
|
* @type: type of the BAR
|
||||||
|
* @res: resource buffer to be filled in
|
||||||
|
* @pos: BAR position in the config space
|
||||||
|
*
|
||||||
|
* Returns 1 if the BAR is 64-bit, or 0 if 32-bit.
|
||||||
*/
|
*/
|
||||||
static int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type,
|
int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type,
|
||||||
struct resource *res, unsigned int pos)
|
struct resource *res, unsigned int pos)
|
||||||
{
|
{
|
||||||
u32 l, sz, mask;
|
u32 l, sz, mask;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user