diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-10-02 18:52:51 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-10-02 18:52:51 -0700 |
commit | b5ff7df3df9efab511244d5a299fce706c71af48 (patch) | |
tree | 77e8d77ebc7f52ee5c28e6652d26fe33739cb4b4 /security | |
parent | 6f92a6a7ddba5ae7ca0f0255d46410465dcf2ba6 (diff) | |
download | kernel-crypto-b5ff7df3df9efab511244d5a299fce706c71af48.tar.gz kernel-crypto-b5ff7df3df9efab511244d5a299fce706c71af48.tar.xz kernel-crypto-b5ff7df3df9efab511244d5a299fce706c71af48.zip |
Check mapped ranges on sysfs resource files
This is loosely based on a patch by Jesse Barnes to check the user-space
PCI mappings though the sysfs interfaces. Quoting Jesse's original
explanation:
It's fairly common for applications to map PCI resources through sysfs.
However, with the current implementation, it's possible for an application
to map far more than the range corresponding to the resourceN file it
opened. This patch plugs that hole by checking the range at mmap time,
similar to what is done on platforms like sparc64 in their lower level
PCI remapping routines.
It was initially put together to help debug the e1000e NVRAM corruption
problem, since we initially thought an X driver might be walking past the
end of one of its mappings and clobbering the NVRAM. It now looks like
that's not the case, but doing the check is still important for obvious
reasons.
and this version of the patch differs in that it uses a helper function
to clarify the code, and does all the checks in pages (instead of bytes)
in order to avoid overflows when doing "<< PAGE_SHIFT" etc.
Acked-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'security')
0 files changed, 0 insertions, 0 deletions