aboutsummaryrefslogtreecommitdiffstats
path: root/include/acpi
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@woody.linux-foundation.org>2008-02-13 09:56:14 -0800
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2008-02-13 09:56:14 -0800
commit10270d4838bdc493781f5a1cf2e90e9c34c9142f (patch)
treed9bce90a79be42ffd619b65b42e9a699bf0d13a6 /include/acpi
parentd897d2b597167586fcf1fb197ad5a1c23332c3e8 (diff)
downloadkernel_samsung_tuna-10270d4838bdc493781f5a1cf2e90e9c34c9142f.zip
kernel_samsung_tuna-10270d4838bdc493781f5a1cf2e90e9c34c9142f.tar.gz
kernel_samsung_tuna-10270d4838bdc493781f5a1cf2e90e9c34c9142f.tar.bz2
acpi: fix acpi_os_read_pci_configuration() misuse of raw_pci_read()
The raw_pci_read() interface (as the raw_pci_ops->read() before it) unconditionally fills in a 32-bit integer return value regardless of the size of the operation requested. So claiming to take a "void *" is wrong, as is passing in a pointer to just a byte variable. Noticed by pageexec when enabling -fstack-protector (which needs other patches too to actually work, but that's a separate issue). Acked-by: Len Brown <len.brown@intel.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'include/acpi')
-rw-r--r--include/acpi/acpiosxf.h2
1 files changed, 1 insertions, 1 deletions
diff --git a/include/acpi/acpiosxf.h b/include/acpi/acpiosxf.h
index 022a5fd..4839f2a 100644
--- a/include/acpi/acpiosxf.h
+++ b/include/acpi/acpiosxf.h
@@ -222,7 +222,7 @@ acpi_os_write_memory(acpi_physical_address address, u32 value, u32 width);
*/
acpi_status
acpi_os_read_pci_configuration(struct acpi_pci_id *pci_id,
- u32 reg, void *value, u32 width);
+ u32 reg, u32 *value, u32 width);
acpi_status
acpi_os_write_pci_configuration(struct acpi_pci_id *pci_id,