1. 11 Jun, 2007 9 commits
  2. 07 Jun, 2007 5 commits
  3. 24 May, 2007 2 commits
  4. 02 May, 2007 24 commits
    • Greg Kroah-Hartman's avatar
      Linux 2.6.20.11 · 6b99a174
      Greg Kroah-Hartman authored
      6b99a174
    • Bartlomiej Zolnierkiewicz's avatar
      Revert "adjust legacy IDE resource setting (v2)" · 481576e9
      Bartlomiej Zolnierkiewicz authored
      Revert "adjust legacy IDE resource setting (v2)"
      
      This reverts commit ed8ccee0.
      
      It causes hang on boot for some users and we don't yet know why:
      
      http://bugzilla.kernel.org/show_bug.cgi?id=7562
      
      http://lkml.org/lkml/2007/4/20/404
      http://lkml.org/lkml/2007/3/25/113
      
      Just reverse it for 2.6.21-final, having broken X server is somehow
      better than unbootable system.
      Signed-off-by: default avatarBartlomiej Zolnierkiewicz <bzolnier@gmail.com>
      Cc: Chuck Ebbert <cebbert@redhat.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      481576e9
    • Jens Axboe's avatar
      cfq-iosched: fix alias + front merge bug · 3720eda5
      Jens Axboe authored
      There's a really rare and obscure bug in CFQ, that causes a crash in
      cfq_dispatch_insert() due to rq == NULL. One example of that is seen
      here:
      
      http://lkml.org/lkml/2007/4/15/41
      
      Neil correctly diagnosed the situation for how this can happen, read
      that analysis here:
      
      http://lkml.org/lkml/2007/4/25/57
      
      This looks like it requires md to trigger, even though it should
      potentially be possible to due with O_DIRECT (at least if you edit the
      kernel and doctor some of the unplug calls).
      
      The fix is to move the ->next_rq update to when we add a request to the
      rbtree. Then we remove the possibility for a request to exist in the
      rbtree code, but not have ->next_rq correctly updated.
      Signed-off-by: default avatarJens Axboe <jens.axboe@oracle.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      3720eda5
    • Wang Zhenyu's avatar
      AGPGART: intel_agp: fix G965 GTT size detect · ab02a657
      Wang Zhenyu authored
      [AGPGART] intel_agp: fix G965 GTT size detect
      
      On G965, I810_PGETBL_CTL is a mmio offset, but we wrongly take it
      as pci config space offset in detecting GTT size. This one line patch
      fixs this.
      Signed-off-by: default avatarWang Zhenyu <zhenyu.z.wang@intel.com>
      Signed-off-by: default avatarDave Jones <davej@redhat.com>
      Cc: Chuck Ebbert <cebbert@redhat.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      ab02a657
    • Tommi Kyntola's avatar
      ALSA: intel8x0 - Fix speaker output after S2RAM · 27797cc7
      Tommi Kyntola authored
      [ALSA] intel8x0 - Fix speaker output after S2RAM
      
      Fixed the mute speaker problem after S2RAM on some laptops:
      	http://bugme.osdl.org/show_bug.cgi?id=6181Signed-off-by: default avatarTommi Kyntola <tommi.kyntola@ray.fi>
      Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      Signed-off-by: default avatarJaroslav Kysela <perex@suse.cz>
      Cc: Chuck Ebbert <cebbert@redhat.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      
      27797cc7
    • Jean Delvare's avatar
      hwmon/w83627ehf: Fix the fan5 clock divider write · 87b814c9
      Jean Delvare authored
      Users have been complaining about the w83627ehf driver flooding their
      logs with debug messages like:
      
      w83627ehf 9191-0a10: Increasing fan 4 clock divider from 64 to 128
      
      or:
      
      w83627ehf 9191-0290: Increasing fan 4 clock divider from 4 to 8
      
      The reason is that we failed to actually write the LSB of the encoded
      clock divider value for that fan, causing the next read to report the
      same old value again and again.
      
      Additionally, the fan number was improperly reported, making the bug
      harder to find.
      Signed-off-by: default avatarJean Delvare <khali@linux-fr.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      87b814c9
    • Jeff Mahoney's avatar
      reiserfs: fix xattr root locking/refcount bug · 1b3bac16
      Jeff Mahoney authored
      The listxattr() and getxattr() operations are only protected by a read
      lock.  As a result, if either of these operations run in parallel, a race
      condition exists where the xattr_root will end up being cached twice, which
      results in the leaking of a reference and a BUG() on umount.
      
      This patch refactors get_xa_root(), __get_xa_root(), and create_xa_root(),
      into one get_xa_root() function that takes the appropriate locking around
      the entire critical section.
      
      Reported, diagnosed and tested by Andrea Righi <a.righi@cineca.it>
      Signed-off-by: default avatarJeff Mahoney <jeffm@suse.com>
      Cc: Andrea Righi <a.righi@cineca.it>
      Cc: "Vladimir V. Saveliev" <vs@namesys.com>
      Cc: Edward Shishkin <edward@namesys.com>
      Cc: Alex Zarochentsev <zam@namesys.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      1b3bac16
    • Balbir Singh's avatar
      Taskstats fix the structure members alignment issue · 2b2c594d
      Balbir Singh authored
      We broke the the alignment of members of taskstats to the 8 byte boundary
      with the CSA patches.  In the current kernel, the taskstats structure is
      not suitable for use by 32 bit applications in a 64 bit kernel.
      
      On x86_64
      
      Offsets of taskstats' members (64 bit kernel, 64 bit application)
      
      @taskstats'offsetof[@taskstats'indices] = (
              0,      # version
              4,      # ac_exitcode
              8,      # ac_flag
              9,      # ac_nice
              16,     # cpu_count
              24,     # cpu_delay_total
              32,     # blkio_count
              40,     # blkio_delay_total
              48,     # swapin_count
              56,     # swapin_delay_total
              64,     # cpu_run_real_total
              72,     # cpu_run_virtual_total
              80,     # ac_comm
              112,    # ac_sched
              113,    # ac_pad
              116,    # ac_uid
              120,    # ac_gid
              124,    # ac_pid
              128,    # ac_ppid
              132,    # ac_btime
              136,    # ac_etime
              144,    # ac_utime
              152,    # ac_stime
              160,    # ac_minflt
              168,    # ac_majflt
              176,    # coremem
              184,    # virtmem
              192,    # hiwater_rss
              200,    # hiwater_vm
              208,    # read_char
              216,    # write_char
              224,    # read_syscalls
              232,    # write_syscalls
              240,    # read_bytes
              248,    # write_bytes
              256,    # cancelled_write_bytes
          );
      
      Offsets of taskstats' members (64 bit kernel, 32 bit application)
      
      @taskstats'offsetof[@taskstats'indices] = (
              0,      # version
              4,      # ac_exitcode
              8,      # ac_flag
              9,      # ac_nice
              12,     # cpu_count
              20,     # cpu_delay_total
              28,     # blkio_count
              36,     # blkio_delay_total
              44,     # swapin_count
              52,     # swapin_delay_total
              60,     # cpu_run_real_total
              68,     # cpu_run_virtual_total
              76,     # ac_comm
              108,    # ac_sched
              109,    # ac_pad
              112,    # ac_uid
              116,    # ac_gid
              120,    # ac_pid
              124,    # ac_ppid
              128,    # ac_btime
              132,    # ac_etime
              140,    # ac_utime
              148,    # ac_stime
              156,    # ac_minflt
              164,    # ac_majflt
              172,    # coremem
              180,    # virtmem
              188,    # hiwater_rss
              196,    # hiwater_vm
              204,    # read_char
              212,    # write_char
              220,    # read_syscalls
              228,    # write_syscalls
              236,    # read_bytes
              244,    # write_bytes
              252,    # cancelled_write_bytes
          );
      
      This is one way to solve the problem without re-arranging structure members
      is to pack the structure.  The patch adds an __attribute__((aligned(8))) to
      the taskstats structure members so that 32 bit applications using taskstats
      can work with a 64 bit kernel.
      
      Using __attribute__((packed)) would break the 64 bit alignment of members.
      
      The fix was tested on x86_64. After the fix, we got
      
      Offsets of taskstats' members (64 bit kernel, 64 bit application)
      
      @taskstats'offsetof[@taskstats'indices] = (
              0,      # version
              4,      # ac_exitcode
              8,      # ac_flag
              9,      # ac_nice
              16,     # cpu_count
              24,     # cpu_delay_total
              32,     # blkio_count
              40,     # blkio_delay_total
              48,     # swapin_count
              56,     # swapin_delay_total
              64,     # cpu_run_real_total
              72,     # cpu_run_virtual_total
              80,     # ac_comm
              112,    # ac_sched
              113,    # ac_pad
              120,    # ac_uid
              124,    # ac_gid
              128,    # ac_pid
              132,    # ac_ppid
              136,    # ac_btime
              144,    # ac_etime
              152,    # ac_utime
              160,    # ac_stime
              168,    # ac_minflt
              176,    # ac_majflt
              184,    # coremem
              192,    # virtmem
              200,    # hiwater_rss
              208,    # hiwater_vm
              216,    # read_char
              224,    # write_char
              232,    # read_syscalls
              240,    # write_syscalls
              248,    # read_bytes
              256,    # write_bytes
              264,    # cancelled_write_bytes
          );
      
      Offsets of taskstats' members (64 bit kernel, 32 bit application)
      
      @taskstats'offsetof[@taskstats'indices] = (
              0,      # version
              4,      # ac_exitcode
              8,      # ac_flag
              9,      # ac_nice
              16,     # cpu_count
              24,     # cpu_delay_total
              32,     # blkio_count
              40,     # blkio_delay_total
              48,     # swapin_count
              56,     # swapin_delay_total
              64,     # cpu_run_real_total
              72,     # cpu_run_virtual_total
              80,     # ac_comm
              112,    # ac_sched
              113,    # ac_pad
              120,    # ac_uid
              124,    # ac_gid
              128,    # ac_pid
              132,    # ac_ppid
              136,    # ac_btime
              144,    # ac_etime
              152,    # ac_utime
              160,    # ac_stime
              168,    # ac_minflt
              176,    # ac_majflt
              184,    # coremem
              192,    # virtmem
              200,    # hiwater_rss
              208,    # hiwater_vm
              216,    # read_char
              224,    # write_char
              232,    # read_syscalls
              240,    # write_syscalls
              248,    # read_bytes
              256,    # write_bytes
              264,    # cancelled_write_bytes
          );
      Signed-off-by: default avatarBalbir Singh <balbir@linux.vnet.ibm.com>
      Cc: Jay Lan <jlan@engr.sgi.com>
      Cc: Shailabh Nagar <nagar@watson.ibm.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      2b2c594d
    • Christoph Lameter's avatar
      page migration: fix NR_FILE_PAGES accounting · 637fc7e4
      Christoph Lameter authored
      NR_FILE_PAGES must be accounted for depending on the zone that the page
      belongs to.  If we replace the page in the radix tree then we may have to
      shift the count to another zone.
      Suggested-by: default avatarEthan Solomita <solo@google.com>
      Cc: Martin Bligh <mbligh@mbligh.org>
      Signed-off-by: default avatarChristoph Lameter <clameter@sgi.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      637fc7e4
    • Taku Izumi's avatar
      Fix possible NULL pointer access in 8250 serial driver · aad6bcca
      Taku Izumi authored
      I encountered the following kernel panic.  The cause of this problem was
      NULL pointer access in check_modem_status() in 8250.c.  I confirmed this
      problem is fixed by the attached patch, but I don't know this is the
      correct fix.
      
      sadc[4378]: NaT consumption 2216203124768 [1]
      Modules linked in: binfmt_misc dm_mirror dm_mod thermal processor fan
      container button sg e100 eepro100 mii ehci_hcd ohci_hcd
      
      Pid: 4378, CPU 0, comm: sadc
      psr : 00001210085a2010 ifs : 8000000000000289 ip : [<a000000100482071>]
      Not tainted
      ip is at check_modem_status+0xf1/0x360
      unat: 0000000000000000 pfs : 0000000000000289 rsc : 0000000000000003
      rnat: 800000000000cc18 bsps: 0000000000000000 pr : 0000000000aa6a99
      ldrs: 0000000000000000 ccv : 0000000000000000 fpsr: 0009804c8a70033f
      csd : 0000000000000000 ssd : 0000000000000000
      b0 : a000000100481fb0 b6 : a0000001004822e0 b7 : a000000100477f20
      f6 : 1003e2222222222222222 f7 : 0ffdba200000000000000
      f8 : 100018000000000000000 f9 : 10002a000000000000000
      f10 : 0fffdccccccccc8c00000 f11 : 1003e0000000000000000
      r1 : a000000100b9af40 r2 : 0000000000000008 r3 : a000000100ad4e21
      r8 : 00000000000000bb r9 : 0000000000000001 r10 : 0000000000000000
      r11 : a000000100ad4d58 r12 : e0000000037b7df0 r13 : e0000000037b0000
      r14 : 0000000000000001 r15 : 0000000000000018 r16 : a000000100ad4d6c
      r17 : 0000000000000000 r18 : 0000000000000000 r19 : 0000000000000000
      r20 : a00000010099bc88 r21 : 00000000000000bb r22 : 00000000000000bb
      r23 : c003fffffc0ff3fe r24 : c003fffffc000000 r25 : 00000000000ff3fe
      r26 : a0000001009b7ad0 r27 : 0000000000000001 r28 : a0000001009b7ad8
      r29 : 0000000000000000 r30 : a0000001009b7ad0 r31 : a0000001009b7ad0
      
      Call Trace:
      [<a000000100013940>] show_stack+0x40/0xa0
      sp=e0000000037b7810 bsp=e0000000037b1118
      [<a0000001000145a0>] show_regs+0x840/0x880
      sp=e0000000037b79e0 bsp=e0000000037b10c0
      [<a0000001000368e0>] die+0x1c0/0x2c0
      sp=e0000000037b79e0 bsp=e0000000037b1078
      [<a000000100036a30>] die_if_kernel+0x50/0x80
      sp=e0000000037b7a00 bsp=e0000000037b1048
      [<a000000100037c40>] ia64_fault+0x11e0/0x1300
      sp=e0000000037b7a00 bsp=e0000000037b0fe8
      [<a00000010000bdc0>] ia64_leave_kernel+0x0/0x280
      sp=e0000000037b7c20 bsp=e0000000037b0fe8
      [<a000000100482070>] check_modem_status+0xf0/0x360
      sp=e0000000037b7df0 bsp=e0000000037b0fa0
      [<a000000100482300>] serial8250_get_mctrl+0x20/0xa0
      sp=e0000000037b7df0 bsp=e0000000037b0f80
      [<a000000100478170>] uart_read_proc+0x250/0x860
      sp=e0000000037b7df0 bsp=e0000000037b0ee0
      [<a0000001001c16d0>] proc_file_read+0x1d0/0x4c0
      sp=e0000000037b7e10 bsp=e0000000037b0e80
      [<a0000001001394b0>] vfs_read+0x1b0/0x300
      sp=e0000000037b7e20 bsp=e0000000037b0e30
      [<a000000100139cd0>] sys_read+0x70/0xe0
      sp=e0000000037b7e20 bsp=e0000000037b0db0
      [<a00000010000bc20>] ia64_ret_from_syscall+0x0/0x20
      sp=e0000000037b7e30 bsp=e0000000037b0db0
      [<a000000000010620>] __kernel_syscall_via_break+0x0/0x20
      sp=e0000000037b8000 bsp=e0000000037b0db0
      
      
      Fix the possible NULL pointer access in check_modem_status() in 8250.c.  The
      check_modem_status() would access 'info' member of uart_port structure, but it
      is not initialized before uart_open() is called.  The check_modem_status() can
      be called through /proc/tty/driver/serial before uart_open() is called.
      Signed-off-by: default avatarKenji Kaneshige <kaneshige.kenji@jp.fujitsu.com>
      Signed-off-by: default avatarTaku Izumi <izumi2005@soft.fujitsu.com>
      Cc: Russell King <rmk@arm.linux.org.uk>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      aad6bcca
    • Hugh Dickins's avatar
      fix OOM killing processes wrongly thought MPOL_BIND · 8505260d
      Hugh Dickins authored
      I only have CONFIG_NUMA=y for build testing: surprised when trying a memhog
      to see lots of other processes killed with "No available memory
      (MPOL_BIND)".  memhog is killed correctly once we initialize nodemask in
      constrained_alloc().
      Signed-off-by: default avatarHugh Dickins <hugh@veritas.com>
      Acked-by: default avatarChristoph Lameter <clameter@sgi.com>
      Acked-by: default avatarWilliam Irwin <bill.irwin@oracle.com>
      Acked-by: default avatarKAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      8505260d
    • Benjamin Herrenschmidt's avatar
      fix bogon in /dev/mem mmap'ing on nommu · b438299c
      Benjamin Herrenschmidt authored
      While digging through my MAP_FIXED changes, I found that rather obvious
      bug in /dev/mem mmap implementation for nommu archs. get_unmapped_area()
      is expected to return an address, not a pfn.
      Signed-off-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
      Acked-By: default avatarDavid Howells <dhowells@redhat.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      b438299c
    • James Bottomley's avatar
      3w-xxxx: fix oops caused by incorrect REQUEST_SENSE handling · 86f757f0
      James Bottomley authored
      3w-xxxx emulates a REQUEST_SENSE response by simply returning nothing.
      Unfortunately, it's assuming that the REQUEST_SENSE command is
      implemented with use_sg == 0, which is no longer the case.  The oops
      occurs because it's clearing the scatterlist in request_buffer instead
      of the memory region.
      
      This is fixed by using tw_transfer_internal() to transfer correctly to
      the scatterlist.
      Acked-by: default avataradam radford <aradford@gmail.com>
      Signed-off-by: default avatarJames Bottomley <James.Bottomley@SteelEye.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      86f757f0
    • Michal Januszewski's avatar
      vt: fix potential race in VT_WAITACTIVE handler · 93c27c73
      Michal Januszewski authored
      [PATCH] vt: fix potential race in VT_WAITACTIVE handler
      
      On a multiprocessor machine the VT_WAITACTIVE ioctl call may return 0 if
      fg_console has already been updated in redraw_screen() but the console
      switch itself hasn't been completed.  Fix this by checking fg_console in
      vt_waitactive() with the console sem held.
      Signed-off-by: default avatarMichal Januszewski <spock@gentoo.org>
      Acked-by: default avatarAntonino Daplas <adaplas@pol.net>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      Cc: Chuck Ebbert <cebbert@redhat.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      93c27c73
    • Zwane Mwaikambo's avatar
      x86: Don't probe for DDC on VBE1.2 · 21deacab
      Zwane Mwaikambo authored
      [PATCH] x86: Don't probe for DDC on VBE1.2
      
      VBE1.2 doesn't support function 15h (DDC) resulting in a 'hang' whilst
      uncompressing kernel with some video cards. Make sure we check VBE version
      before fiddling around with DDC.
      
      http://bugzilla.kernel.org/show_bug.cgi?id=1458
      
      Opened: 2003-10-30 09:12 Last update: 2007-02-13 22:03
      
      Much thanks to Tobias Hain for help in testing and investigating the bug.
      Tested on;
      
      i386, Chips & Technologies 65548 VESA VBE 1.2
      CONFIG_VIDEO_SELECT=Y
      CONFIG_FIRMWARE_EDID=Y
      
      Untested on x86_64.
      Signed-off-by: default avatarZwane Mwaikambo <zwane@infradead.org>
      Signed-off-by: default avatarAndi Kleen <ak@suse.de>
      Cc: Chuck Ebbert <cebbert@redhat.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      21deacab
    • Trond Myklebust's avatar
      NFS: Fix an Oops in nfs_setattr() · d0769f55
      Trond Myklebust authored
      NFS: Fix an Oops in nfs_setattr()
      
      It looks like nfs_setattr() and nfs_rename() also need to test whether the
      target is a regular file before calling nfs_wb_all()...
      Signed-off-by: default avatarTrond Myklebust <Trond.Myklebust@netapp.com>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      Cc: Chuck Ebbert <cebbert@redhat.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      d0769f55
    • Alan Cox's avatar
      exec.c: fix coredump to pipe problem and obscure "security hole" · 12b1ca66
      Alan Cox authored
      exec.c: fix coredump to pipe problem and obscure "security hole"
      
      The patch checks for "|" in the pattern not the output and doesn't nail a
      pid on to a piped name (as it is a program name not a file)
      
      Also fixes a very very obscure security corner case.  If you happen to have
      decided on a core pattern that starts with the program name then the user
      can run a program called "|myevilhack" as it stands.  I doubt anyone does
      this.
      Signed-off-by: default avatarAlan Cox <alan@redhat.com>
      Confirmed-by: default avatarChristopher S. Aker <caker@theshore.net>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      12b1ca66
    • Badari Pulavarty's avatar
      cache_k8_northbridges() overflows beyond allocation · a9c01941
      Badari Pulavarty authored
      cache_k8_northbridges() overflows beyond allocation
      
      cache_k8_northbridges() is storing config values to incorrect locations
      (in flush_words) and also its overflowing beyond the allocation, causing
      slab verification failures.
      Signed-off-by: default avatarBadari Pulavarty <pbadari@us.ibm.com>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      Cc: Andi Kleen <andi@firstfloor.org>
      Cc: Chuck Ebbert <cebbert@redhat.com>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      a9c01941
    • Olaf Kirch's avatar
      Fix IRDA oops'er · 1ee88fb6
      Olaf Kirch authored
      This fixes and OOPS due to incorrect socket orpahning in the
      IRDA stack.
      
      [IrDA]: Correctly handling socket error
      
      This patch fixes an oops first reported in mid 2006 - see
      http://lkml.org/lkml/2006/8/29/358 The cause of this bug report is that
      when an error is signalled on the socket, irda_recvmsg_stream returns
      without removing a local wait_queue variable from the socket's sk_sleep
      queue. This causes havoc further down the road.
      
      In response to this problem, a patch was made that invoked sock_orphan on
      the socket when receiving a disconnect indication. This is not a good fix,
      as this sets sk_sleep to NULL, causing applications sleeping in recvmsg
      (and other places) to oops.
      
      This is against the latest net-2.6 and should be considered for -stable
      inclusion.
      Signed-off-by: default avatarOlaf Kirch <olaf.kirch@oracle.com>
      Signed-off-by: default avatarSamuel Ortiz <samuel@sortiz.org>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      1ee88fb6
    • Aubrey.Li's avatar
      Fix netpoll UDP input path · 100f4756
      Aubrey.Li authored
      Netpoll UDP input handler needs to pull up the UDP headers
      and handle receive checksum offloading properly just like
      the normal UDP input path does else we get corrupted
      checksums.
      
      [NET]: Fix UDP checksum issue in net poll mode.
      
      In net poll mode, the current checksum function doesn't consider the
      kind of packet which is padded to reach a specific minimum length. I
      believe that's the problem causing my test case failed. The following
      patch fixed this issue.
      Signed-off-by: default avatarAubrey.Li <aubreylee@gmail.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      100f4756
    • John Heffner's avatar
      Fix errors in tcp_mem[] calculations. · 3300bb14
      John Heffner authored
      In 2.6.18 a change was made to the tcp_mem[] calculations,
      but this causes regressions for some folks up to 2.6.20
      
      The following fix to smooth out the calculation from the
      pending 2.6.21 tree by John Heffner fixes the problem for
      these folks.
      
      [TCP]: Fix tcp_mem[] initialization.
      
      Change tcp_mem initialization function.  The fraction of total memory
      is now a continuous function of memory size, and independent of page
      size.
      Signed-off-by: default avatarJohn Heffner <jheffner@psc.edu>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      3300bb14
    • Tom "spot" Callaway's avatar
      Fix bogus inline directive in sparc64 PCI code · 979a764e
      Tom "spot" Callaway authored
      [SPARC64]: Fix inline directive in pci_iommu.c
      
      While building a test kernel for the new esp driver (against
      git-current), I hit this bug. Trivial fix, put the inline declaration
      in the right place. :)
      Signed-off-by: default avatarTom "spot" Callaway <tcallawa@redhat.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      979a764e
    • David Miller's avatar
      Fix compat sys_ipc() on sparc64 · a95330df
      David Miller authored
      The 32-bit syscall trampoline for sys_ipc() on sparc64
      was sign extending various arguments, which is bogus when
      using compat_sys_ipc() since that function expects zero
      extended copies of all the arguments.
      
      This bug breaks the sparc64 kernel when built with gcc-4.2.x
      among other things.
      
      [SPARC64]: Fix arg passing to compat_sys_ipc().
      
      Do not sign extend args using the sys32_ipc stub, that is
      buggy and unnecessary.
      
      Based upon an excellent report by Mikael Pettersson.
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      a95330df
    • David Miller's avatar
      Fix qlogicpti DMA unmapping · d3bf6f8a
      David Miller authored
      [SCSI] QLOGICPTI: Do not unmap DMA unless we actually mapped something.
      
      We only map DMA when cmd->request_bufflen is non-zero for non-sg
      buffers, we thus should make the same check when unmapping.
      
      Based upon a report from Pasi Pirhonen.
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      d3bf6f8a