Merge branch 'for-linus' of git://one.firstfloor.org/home/andi/git/linux-2.6
* 'for-linus' of git://one.firstfloor.org/home/andi/git/linux-2.6: (231 commits) [PATCH] i386: Don't delete cpu_devs data to identify different x86 types in late_initcall [PATCH] i386: type may be unused [PATCH] i386: Some additional chipset register values validation. [PATCH] i386: Add missing !X86_PAE dependincy to the 2G/2G split. [PATCH] x86-64: Don't exclude asm-offsets.c in Documentation/dontdiff [PATCH] i386: avoid redundant preempt_disable in __unlazy_fpu [PATCH] i386: white space fixes in i387.h [PATCH] i386: Drop noisy e820 debugging printks [PATCH] x86-64: Fix allnoconfig error in genapic_flat.c [PATCH] x86-64: Shut up warnings for vfat compat ioctls on other file systems [PATCH] x86-64: Share identical video.S between i386 and x86-64 [PATCH] x86-64: Remove CONFIG_REORDER [PATCH] x86-64: Print type and size correctly for unknown compat ioctls [PATCH] i386: Remove copy_*_user BUG_ONs for (size < 0) [PATCH] i386: Little cleanups in smpboot.c [PATCH] x86-64: Don't enable NUMA for a single node in K8 NUMA scanning [PATCH] x86: Use RDTSCP for synchronous get_cycles if possible [PATCH] i386: Add X86_FEATURE_RDTSCP [PATCH] i386: Implement X86_FEATURE_SYNC_RDTSC on i386 [PATCH] i386: Implement alternative_io for i386 ... Fix up trivial conflict in include/linux/highmem.h manually. Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
@@ -371,13 +371,14 @@ static void compat_ioctl_error(struct file *filp, unsigned int fd,
|
||||
fn = "?";
|
||||
}
|
||||
|
||||
sprintf(buf,"'%c'", (cmd>>24) & 0x3f);
|
||||
sprintf(buf,"'%c'", (cmd>>_IOC_TYPESHIFT) & _IOC_TYPEMASK);
|
||||
if (!isprint(buf[1]))
|
||||
sprintf(buf, "%02x", buf[1]);
|
||||
compat_printk("ioctl32(%s:%d): Unknown cmd fd(%d) "
|
||||
"cmd(%08x){%s} arg(%08x) on %s\n",
|
||||
"cmd(%08x){t:%s;sz:%u} arg(%08x) on %s\n",
|
||||
current->comm, current->pid,
|
||||
(int)fd, (unsigned int)cmd, buf,
|
||||
(cmd >> _IOC_SIZESHIFT) & _IOC_SIZEMASK,
|
||||
(unsigned int)arg, fn);
|
||||
|
||||
if (path)
|
||||
|
@@ -2396,6 +2396,14 @@ lp_timeout_trans(unsigned int fd, unsigned int cmd, unsigned long arg)
|
||||
#define ULONG_IOCTL(cmd) \
|
||||
{ (cmd), (ioctl_trans_handler_t)sys_ioctl },
|
||||
|
||||
/* ioctl should not be warned about even if it's not implemented.
|
||||
Valid reasons to use this:
|
||||
- It is implemented with ->compat_ioctl on some device, but programs
|
||||
call it on others too.
|
||||
- The ioctl is not implemented in the native kernel, but programs
|
||||
call it commonly anyways.
|
||||
Most other reasons are not valid. */
|
||||
#define IGNORE_IOCTL(cmd) COMPATIBLE_IOCTL(cmd)
|
||||
|
||||
struct ioctl_trans ioctl_start[] = {
|
||||
#include <linux/compat_ioctl.h>
|
||||
@@ -2594,6 +2602,8 @@ HANDLE_IOCTL(SIOCGIWENCODEEXT, do_wireless_ioctl)
|
||||
HANDLE_IOCTL(SIOCSIWPMKSA, do_wireless_ioctl)
|
||||
HANDLE_IOCTL(SIOCSIFBR, old_bridge_ioctl)
|
||||
HANDLE_IOCTL(SIOCGIFBR, old_bridge_ioctl)
|
||||
/* Not implemented in the native kernel */
|
||||
IGNORE_IOCTL(SIOCGIFCOUNT)
|
||||
HANDLE_IOCTL(RTC_IRQP_READ32, rtc_ioctl)
|
||||
HANDLE_IOCTL(RTC_IRQP_SET32, rtc_ioctl)
|
||||
HANDLE_IOCTL(RTC_EPOCH_READ32, rtc_ioctl)
|
||||
@@ -2617,6 +2627,15 @@ COMPATIBLE_IOCTL(LPRESET)
|
||||
/*LPGETSTATS not implemented, but no kernels seem to compile it in anyways*/
|
||||
COMPATIBLE_IOCTL(LPGETFLAGS)
|
||||
HANDLE_IOCTL(LPSETTIMEOUT, lp_timeout_trans)
|
||||
|
||||
/* fat 'r' ioctls. These are handled by fat with ->compat_ioctl,
|
||||
but we don't want warnings on other file systems. So declare
|
||||
them as compatible here. */
|
||||
#define VFAT_IOCTL_READDIR_BOTH32 _IOR('r', 1, struct compat_dirent[2])
|
||||
#define VFAT_IOCTL_READDIR_SHORT32 _IOR('r', 2, struct compat_dirent[2])
|
||||
|
||||
IGNORE_IOCTL(VFAT_IOCTL_READDIR_BOTH32)
|
||||
IGNORE_IOCTL(VFAT_IOCTL_READDIR_SHORT32)
|
||||
};
|
||||
|
||||
int ioctl_table_size = ARRAY_SIZE(ioctl_start);
|
||||
|
@@ -514,7 +514,7 @@ static int __init parse_crash_elf64_headers(void)
|
||||
/* Do some basic Verification. */
|
||||
if (memcmp(ehdr.e_ident, ELFMAG, SELFMAG) != 0 ||
|
||||
(ehdr.e_type != ET_CORE) ||
|
||||
!elf_check_arch(&ehdr) ||
|
||||
!vmcore_elf_check_arch(&ehdr) ||
|
||||
ehdr.e_ident[EI_CLASS] != ELFCLASS64 ||
|
||||
ehdr.e_ident[EI_VERSION] != EV_CURRENT ||
|
||||
ehdr.e_version != EV_CURRENT ||
|
||||
|
Reference in New Issue
Block a user