x86: truncate ISA addresses to unsigned int
Impact: Cleanup; fix inappropriate macro use ISA addresses on x86 are mapped 1:1 with the physical address space. Since the ISA address space is only 24 bits (32 for VLB or LPC) it will always fit in an unsigned int, and at least in the aha1542 driver using a wider type would cause an undesirable promotion. Hence explicitly cast the ISA bus addresses to unsigned int. Signed-off-by: H. Peter Anvin <hpa@linux.intel.com> Cc: James Bottomley <James.Bottomley@hansenpartnership.com>
This commit is contained in:
parent
ee8b53c1cf
commit
a7eb518998
|
@ -124,10 +124,15 @@ static inline void *phys_to_virt(phys_addr_t address)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* ISA I/O bus memory addresses are 1:1 with the physical address.
|
* ISA I/O bus memory addresses are 1:1 with the physical address.
|
||||||
|
* However, we truncate the address to unsigned int to avoid undesirable
|
||||||
|
* promitions in legacy drivers.
|
||||||
*/
|
*/
|
||||||
#define isa_virt_to_bus (unsigned long)virt_to_phys
|
static inline unsigned int isa_virt_to_bus(volatile void *address)
|
||||||
#define isa_page_to_bus page_to_phys
|
{
|
||||||
#define isa_bus_to_virt phys_to_virt
|
return (unsigned int)virt_to_phys(address);
|
||||||
|
}
|
||||||
|
#define isa_page_to_bus(page) ((unsigned int)page_to_phys(page))
|
||||||
|
#define isa_bus_to_virt phys_to_virt
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* However PCI ones are not necessarily 1:1 and therefore these interfaces
|
* However PCI ones are not necessarily 1:1 and therefore these interfaces
|
||||||
|
|
Loading…
Reference in New Issue