-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[PATCH] x86: Move direct PCI scanning functions out of line
Saves about 200 bytes of code space. Signed-off-by: Andi Kleen <ak@suse.de>
- Loading branch information
Andi Kleen
authored and
Andi Kleen
committed
Sep 26, 2006
1 parent
f157cbb
commit 8f60774
Showing
4 changed files
with
51 additions
and
40 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
#include <linux/kernel.h> | ||
#include <asm/pci-direct.h> | ||
#include <asm/io.h> | ||
|
||
/* Direct PCI access. This is used for PCI accesses in early boot before | ||
the PCI subsystem works. */ | ||
|
||
#define PDprintk(x...) | ||
|
||
u32 read_pci_config(u8 bus, u8 slot, u8 func, u8 offset) | ||
{ | ||
u32 v; | ||
outl(0x80000000 | (bus<<16) | (slot<<11) | (func<<8) | offset, 0xcf8); | ||
v = inl(0xcfc); | ||
if (v != 0xffffffff) | ||
PDprintk("%x reading 4 from %x: %x\n", slot, offset, v); | ||
return v; | ||
} | ||
|
||
u8 read_pci_config_byte(u8 bus, u8 slot, u8 func, u8 offset) | ||
{ | ||
u8 v; | ||
outl(0x80000000 | (bus<<16) | (slot<<11) | (func<<8) | offset, 0xcf8); | ||
v = inb(0xcfc + (offset&3)); | ||
PDprintk("%x reading 1 from %x: %x\n", slot, offset, v); | ||
return v; | ||
} | ||
|
||
u16 read_pci_config_16(u8 bus, u8 slot, u8 func, u8 offset) | ||
{ | ||
u16 v; | ||
outl(0x80000000 | (bus<<16) | (slot<<11) | (func<<8) | offset, 0xcf8); | ||
v = inw(0xcfc + (offset&2)); | ||
PDprintk("%x reading 2 from %x: %x\n", slot, offset, v); | ||
return v; | ||
} | ||
|
||
void write_pci_config(u8 bus, u8 slot, u8 func, u8 offset, | ||
u32 val) | ||
{ | ||
PDprintk("%x writing to %x: %x\n", slot, offset, val); | ||
outl(0x80000000 | (bus<<16) | (slot<<11) | (func<<8) | offset, 0xcf8); | ||
outl(val, 0xcfc); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters