06 Sep, 2009

31 commits

  • Until now, retries were only sent when joining a multicast group. This
    patch will adds retries when leaving a multicast group as well.

    Signed-off-by: Ron Livne
    Signed-off-by: Yossi Etigin
    Acked-by: Sean Hefty
    Signed-off-by: Roland Dreier

    Yossi Etigin
     
  • Replace open-coded reimplementations with printk_once().

    Signed-off-by: Marcin Slusarz
    Signed-off-by: Roland Dreier

    Marcin Slusarz
     
  • Use the %pM conversion specifier to print a MAC address.

    Signed-off-by: Tobias Klauser
    Acked-by: Steve Wise
    Signed-off-by: Roland Dreier

    Tobias Klauser
     
  • Rather than just defining static spinlock_t variables and then
    initializing them later in init functions, simply define them with
    DEFINE_SPINLOCK() and remove the calls to spin_lock_init(). This cleans
    up the source a tad and also shrinks the compiled code; eg on x86-64:

    add/remove: 0/0 grow/shrink: 0/3 up/down: 0/-40 (-40)
    function old new delta
    ib_uverbs_init 336 326 -10
    ib_mad_init_module 147 137 -10
    ib_sa_init 123 103 -20

    Signed-off-by: Roland Dreier

    Roland Dreier
     
  • Linus Torvalds
     
  • * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6:
    firewire: sbp2: fix freeing of unallocated memory
    firewire: ohci: fix Ricoh R5C832, video reception
    firewire: ohci: fix Agere FW643 and multiple cameras
    firewire: core: fix crash in iso resource management

    Linus Torvalds
     
  • This patch fixes a null pointer exception caused by removal of
    'ack()' for level interrupts in the Xilinx interrupt driver. A recent
    change to the xilinx interrupt controller removed the ack hook for
    level irqs.

    Signed-off-by: Roderick Colenbrander
    Signed-off-by: Grant Likely
    Acked-by: Benjamin Herrenschmidt
    Signed-off-by: Linus Torvalds

    Roderick Colenbrander
     
  • * git://git.infradead.org/~dwmw2/mtd-2.6.31:
    JFFS2: add missing verify buffer allocation/deallocation
    mtd: nftl: fix offset alignments
    mtd: nftl: write support is broken
    mtd: m25p80: fix null pointer dereference bug

    Linus Torvalds
     
  • * 'for-linus' of git://git.kernel.dk/linux-2.6-block:
    block: Allow changing max_sectors_kb above the default 512

    Linus Torvalds
     
  • * 'fix/oxygen' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound-2.6:
    sound: oxygen: handle cards with missing EEPROM
    sound: oxygen: fix MCLK rate for 192 kHz playback

    Linus Torvalds
     
  • * git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6:
    tc: Fix unitialized kernel memory leak
    pkt_sched: Revert tasklet_hrtimer changes.
    net: sk_free() should be allowed right after sk_alloc()
    gianfar: gfar_remove needs to call unregister_netdev()
    ipw2200: firmware DMA loading rework

    Linus Torvalds
     
  • * git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6:
    crypto: skcipher - Fix skcipher_dequeue_givcrypt NULL test

    Linus Torvalds
     
  • * 'fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/davej/cpufreq:
    [CPUFREQ] Re-enable cpufreq suspend and resume code

    Linus Torvalds
     
  • * 'release' of git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux-2.6:
    [IA64] fix csum_ipv6_magic()
    [IA64] Fix warning in dma-mapping.c

    Linus Torvalds
     
  • * 'for-linus' of git://oss.sgi.com/xfs/xfs:
    xfs: actually enable the swapext compat handler

    Linus Torvalds
     
  • * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/ryusuke/nilfs2:
    nilfs2: fix preempt count underflow in nilfs_btnode_prepare_change_key

    Linus Torvalds
     
  • * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/percpu:
    percpu: don't assume existence of cpu0

    Linus Torvalds
     
  • * 'slab/urgent' of git://git.kernel.org/pub/scm/linux/kernel/git/penberg/slab-2.6:
    slub: Fix kmem_cache_destroy() with SLAB_DESTROY_BY_RCU

    Linus Torvalds
     
  • * git://git.kernel.org/pub/scm/linux/kernel/git/agk/linux-2.6-dm:
    dm snapshot: fix on disk chunk size validation
    dm exception store: split set_chunk_size
    dm snapshot: fix header corruption race on invalidation
    dm snapshot: refactor zero_disk_area to use chunk_io
    dm log: userspace add luid to distinguish between concurrent log instances
    dm raid1: do not allow log_failure variable to unset after being set
    dm log: remove incorrect field from userspace table output
    dm log: fix userspace status output
    dm stripe: expose correct io hints
    dm table: add more context to terse warning messages
    dm table: fix queue_limit checking device iterator
    dm snapshot: implement iterate devices
    dm multipath: fix oops when request based io fails when no paths

    Linus Torvalds
     
  • * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/pci-2.6:
    PCI SR-IOV: correct broken resource alignment calculations

    Linus Torvalds
     
  • * git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-2.6:
    sparc64: Fix bootup with mcount in some configs.
    sparc64: Kill spurious NMI watchdog triggers by increasing limit to 30 seconds.

    Linus Torvalds
     
  • …x/kernel/git/tip/linux-2.6-tip

    * 'perfcounters-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip:
    perf_counter/powerpc: Fix cache event codes for POWER7
    perf_counter: Fix /0 bug in swcounters
    perf_counters: Increase paranoia level

    Linus Torvalds
     
  • * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input:
    Input: atkbd - add Compaq Presario R4000-series repeat quirk
    Input: i8042 - add Acer Aspire 5536 to the nomux list

    Linus Torvalds
     
  • In ext2_rename(), dir_page is acquired through ext2_dotdot(). It is
    then released through ext2_set_link() but only if old_dir != new_dir.
    Failing that, the pkmap reference count is never decremented and the
    page remains pinned forever. Repeat that a couple times with highmem
    pages and all pkmap slots get exhausted, and every further kmap() calls
    end up stalling on the pkmap_map_wait queue at which point the whole
    system comes to a halt.

    Signed-off-by: Nicolas Pitre
    Acked-by: Theodore Ts'o
    Cc: stable@kernel.org
    Signed-off-by: Linus Torvalds

    Nicolas Pitre
     
  • * 'upstream-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jlbec/ocfs2:
    ocfs2: ocfs2_write_begin_nolock() should handle len=0
    ocfs2: invalidate dentry if its dentry_lock isn't initialized.

    Linus Torvalds
     
  • The whole write-room thing is something that is up to the _caller_ to
    worry about, not the pty layer itself. The total buffer space will
    still be limited by the buffering routines themselves, so there is no
    advantage or need in having pty_write() artificially limit the size
    somehow.

    And what happened was that the caller (the n_tty line discipline, in
    this case) may have verified that there is room for 2 bytes to be
    written (for NL -> CRNL expansion), and it used to then do those writes
    as two single-byte writes. And if the first byte written (CR) then
    caused a new tty buffer to be allocated, pty_space() may have returned
    zero when trying to write the second byte (LF), and then incorrectly
    failed the write - leading to a lost newline character.

    This should finally fix

    http://bugzilla.kernel.org/show_bug.cgi?id=14015

    Reported-by: Mikael Pettersson
    Acked-by: Alan Cox
    Signed-off-by: Linus Torvalds

    Linus Torvalds
     
  • When translating CR to CRNL in the n_tty line discipline, we did it as
    two tty_put_char() calls. Which works, but is stupid, and has caused
    problems before too with bad interactions with the write_room() logic.
    The generic USB serial driver had that problem, for example.

    Now the pty layer had similar issues after being moved to the generic
    tty buffering code (in commit d945cb9cce20ac7143c2de8d88b187f62db99bdc:
    "pty: Rework the pty layer to use the normal buffering logic").

    So stop doing the silly separate two writes, and do it as a single write
    instead. That's what the n_tty layer already does for the space
    expansion of tabs (XTABS), and it means that we'll now always have just
    a single write for the CRNL to match the single 'tty_write_room()' test,
    which hopefully means that the next time somebody screws up buffering,
    it won't cause weeks of debugging.

    Signed-off-by: Linus Torvalds

    Linus Torvalds
     
  • Tom Horsley reports that his debugger hangs when it tries to read
    /proc/pid_of_tracee/maps, this happens since

    "mm_for_maps: take ->cred_guard_mutex to fix the race with exec"
    04b836cbf19e885f8366bccb2e4b0474346c02d

    commit in 2.6.31.

    But the root of the problem lies in the fact that do_execve() path calls
    tracehook_report_exec() which can stop if the tracer sets PT_TRACE_EXEC.

    The tracee must not sleep in TASK_TRACED holding this mutex. Even if we
    remove ->cred_guard_mutex from mm_for_maps() and proc_pid_attr_write(),
    another task doing PTRACE_ATTACH should not hang until it is killed or the
    tracee resumes.

    With this patch do_execve() does not use ->cred_guard_mutex directly and
    we do not hold it throughout, instead:

    - introduce prepare_bprm_creds() helper, it locks the mutex
    and calls prepare_exec_creds() to initialize bprm->cred.

    - install_exec_creds() drops the mutex after commit_creds(),
    and thus before tracehook_report_exec()->ptrace_stop().

    or, if exec fails,

    free_bprm() drops this mutex when bprm->cred != NULL which
    indicates install_exec_creds() was not called.

    Reported-by: Tom Horsley
    Signed-off-by: Oleg Nesterov
    Acked-by: David Howells
    Cc: Roland McGrath
    Cc: James Morris
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    Oleg Nesterov
     
  • On low-memory systems, anti-fragmentation gets disabled as fragmentation
    cannot be avoided on a sufficiently large boundary to be worthwhile. Once
    disabled, there is a period of time when all the pageblocks are marked
    MOVABLE and the expectation is that they get marked UNMOVABLE at each call
    to __rmqueue_fallback().

    However, when MAX_ORDER is large the pageblocks do not change ownership
    because the normal criteria are not met. This has the effect of
    prematurely breaking up too many large contiguous blocks. This is most
    serious on NOMMU systems which depend on high-order allocations to boot.
    This patch causes pageblocks to change ownership on every fallback when
    anti-fragmentation is disabled. This prevents the large blocks being
    prematurely broken up.

    This is a fix to commit 49255c619fbd482d704289b5eb2795f8e3b7ff2e [page
    allocator: move check for disabled anti-fragmentation out of fastpath] and
    the problem affects 2.6.31-rc8.

    Signed-off-by: Mel Gorman
    Tested-by: Paul Mundt
    Cc: David Howells
    Cc: Pekka Enberg
    Acked-by: Greg Ungerer
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    Mel Gorman
     
  • Fix the error handling in do_mmap_pgoff(). If do_mmap_shared_file() or
    do_mmap_private() fail, we jump to the error_put_region label at which
    point we cann __put_nommu_region() on the region - but we haven't yet
    added the region to the tree, and so __put_nommu_region() may BUG
    because the region tree is empty or it may corrupt the region tree.

    To get around this, we can afford to add the region to the region tree
    before calling do_mmap_shared_file() or do_mmap_private() as we keep
    nommu_region_sem write-locked, so no-one can race with us by seeing a
    transient region.

    Signed-off-by: David Howells
    Acked-by: Pekka Enberg
    Acked-by: Paul Mundt
    Cc: Mel Gorman
    Acked-by: Greg Ungerer
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Howells
     
  • cancel_delayed_work() has to use del_timer_sync() to guarantee the timer
    function is not running after return. But most users doesn't actually
    need this, and del_timer_sync() has problems: it is not useable from
    interrupt, and it depends on every lock which could be taken from irq.

    Introduce __cancel_delayed_work() which calls del_timer() instead.

    The immediate reason for this patch is
    http://bugzilla.kernel.org/show_bug.cgi?id=13757
    but hopefully this helper makes sense anyway.

    As for 13757 bug, actually we need requeue_delayed_work(), but its
    semantics are not yet clear.

    Merge this patch early to resolves cross-tree interdependencies between
    input and infiniband.

    Signed-off-by: Oleg Nesterov
    Cc: Dmitry Torokhov
    Cc: Roland Dreier
    Cc: Stefan Richter
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    Oleg Nesterov
     

05 Sep, 2009

9 commits

  • If a target writes invalid status (typically status of a command that
    already timed out), firewire-sbp2 attempts to put away an ORB that
    doesn't exist. https://bugzilla.redhat.com/show_bug.cgi?id=519772

    Signed-off-by: Stefan Richter

    Stefan Richter
     
  • In dual-buffer DMA mode, no video frames are ever received from R5C832
    by libdc1394. Fallback to packet-per-buffer DMA works reliably.
    http://thread.gmane.org/gmane.linux.kernel.firewire.devel/13393/focus=13476

    Reported-by: Jonathan Cameron
    Signed-off-by: Stefan Richter

    Stefan Richter
     
  • An Agere FW643 OHCI 1.1 card works fine for video reception from one
    camera but fails early if receiving from two cameras. After a short
    while, no IR IRQ events occur and the context control register does not
    react anymore. This happens regardless whether both IR DMA contexts are
    dual-buffer or one is dual-buffer and the other packet-per-buffer.

    This can be worked around by disabling dual buffer DMA mode entirely.
    http://sourceforge.net/mailarchive/message.php?msg_name=4A7C0594.2020208%40gmail.com
    (Reported by Samuel Audet.)

    In another report (by Jonathan Cameron), an FW643 works OK with two
    cameras in dual buffer mode. Whether this is due to different chip
    revisions or different usage patterns (different video formats) is not
    yet clear. However, as far as the current capabilities of
    firewire-core's isochronous I/O interface are concerned, simply
    switching off dual-buffer on non-working and working FW643s alike is not
    a problem in practice. We only need to revisit this issue if we are
    going to enhance the interface, e.g. so that applications can explicitly
    choose modes.

    Reported-by: Samuel Audet
    Reported-by: Jonathan Cameron
    Signed-off-by: Stefan Richter

    Stefan Richter
     
  • This fixes a regression due to post 2.6.30 commit "firewire: core: do
    not DMA-map stack addresses" 6fdc03709433ccc2005f0f593ae9d9dd04f7b485.

    As David Moore noted, a previously correct sizeof() expression became
    wrong since the commit changed its argument from an array to a pointer.
    This resulted in an oops in ohci_cancel_packet in the shared workqueue
    thread's context when an isochronous resource was to be freed.

    Reported-by: Jonathan Cameron
    Signed-off-by: Stefan Richter

    Stefan Richter
     
  • Bug introduced by mainline commit e7432675f8ca868a4af365759a8d4c3779a3d922
    The bug causes ocfs2_write_begin_nolock() to oops when len=0.

    Signed-off-by: Sunil Mushran
    Cc: stable@kernel.org
    Signed-off-by: Joel Becker

    Sunil Mushran
     
  • Fix some problems seen in the chunk size processing when activating a
    pre-existing snapshot.

    For a new snapshot, the chunk size can either be supplied by the creator
    or a default value can be used. For an existing snapshot, the
    chunk size in the snapshot header on disk should always be used.

    If someone attempts to load an existing snapshot and has the 'default
    chunk size' option set, the kernel uses its default value even when it
    is incorrect for the snapshot being loaded. This patch ensures the
    correct on-disk value is always used.

    Secondly, when the code does use the chunk size stored on the disk it is
    prudent to revalidate it, so the code can exit cleanly if it got
    corrupted as happened in
    https://bugzilla.redhat.com/show_bug.cgi?id=461506 .

    Cc: stable@kernel.org
    Signed-off-by: Mikulas Patocka
    Signed-off-by: Alasdair G Kergon

    Mikulas Patocka
     
  • Break the function set_chunk_size to two functions in preparation for
    the fix in the following patch.

    Cc: stable@kernel.org
    Signed-off-by: Mikulas Patocka
    Signed-off-by: Alasdair G Kergon

    Mikulas Patocka
     
  • If a persistent snapshot fills up, a race can corrupt the on-disk header
    which causes a crash on any future attempt to activate the snapshot
    (typically while booting). This patch fixes the race.

    When the snapshot overflows, __invalidate_snapshot is called, which calls
    snapshot store method drop_snapshot. It goes to persistent_drop_snapshot that
    calls write_header. write_header constructs the new header in the "area"
    location.

    Concurrently, an existing kcopyd job may finish, call copy_callback
    and commit_exception method, that goes to persistent_commit_exception.
    persistent_commit_exception doesn't do locking, relying on the fact that
    callbacks are single-threaded, but it can race with snapshot invalidation and
    overwrite the header that is just being written while the snapshot is being
    invalidated.

    The result of this race is a corrupted header being written that can
    lead to a crash on further reactivation (if chunk_size is zero in the
    corrupted header).

    The fix is to use separate memory areas for each.

    See the bug: https://bugzilla.redhat.com/show_bug.cgi?id=461506

    Cc: stable@kernel.org
    Signed-off-by: Mikulas Patocka
    Signed-off-by: Alasdair G Kergon

    Mikulas Patocka
     
  • Refactor chunk_io to prepare for the fix in the following patch.

    Pass an area pointer to chunk_io and simplify zero_disk_area to use
    chunk_io. No functional change.

    Cc: stable@kernel.org
    Signed-off-by: Mikulas Patocka
    Signed-off-by: Alasdair G Kergon

    Mikulas Patocka