02 Dec, 2009

1 commit


01 Dec, 2009

2 commits

  • The fbdev mailing lists at SourceForge have been migrated to a single
    mailing list at kernel.org: linux-fbdev@vger.kernel.org.

    Signed-off-by: Geert Uytterhoeven
    Acked-by: Jean Delvare
    Signed-off-by: Linus Torvalds

    Geert Uytterhoeven
     
  • * git://git.kernel.org/pub/scm/linux/kernel/git/dhowells/linux-2.6-fscache: (31 commits)
    FS-Cache: Provide nop fscache_stat_d() if CONFIG_FSCACHE_STATS=n
    SLOW_WORK: Fix GFS2 to #include before using THIS_MODULE
    SLOW_WORK: Fix CIFS to pass THIS_MODULE to slow_work_register_user()
    CacheFiles: Don't log lookup/create failing with ENOBUFS
    CacheFiles: Catch an overly long wait for an old active object
    CacheFiles: Better showing of debugging information in active object problems
    CacheFiles: Mark parent directory locks as I_MUTEX_PARENT to keep lockdep happy
    CacheFiles: Handle truncate unlocking the page we're reading
    CacheFiles: Don't write a full page if there's only a partial page to cache
    FS-Cache: Actually requeue an object when requested
    FS-Cache: Start processing an object's operations on that object's death
    FS-Cache: Make sure FSCACHE_COOKIE_LOOKING_UP cleared on lookup failure
    FS-Cache: Add a retirement stat counter
    FS-Cache: Handle pages pending storage that get evicted under OOM conditions
    FS-Cache: Handle read request vs lookup, creation or other cache failure
    FS-Cache: Don't delete pending pages from the page-store tracking tree
    FS-Cache: Fix lock misorder in fscache_write_op()
    FS-Cache: The object-available state can't rely on the cookie to be available
    FS-Cache: Permit cache retrieval ops to be interrupted in the initial wait phase
    FS-Cache: Use radix tree preload correctly in tracking of pages to be stored
    ...

    Linus Torvalds
     

20 Nov, 2009

16 commits

  • * 'upstream-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jlbec/ocfs2:
    ocfs2: Trivial cleanup of jbd compatibility layer removal
    ocfs2: Refresh documentation
    ocfs2: return f_fsid info in ocfs2_statfs()
    ocfs2: duplicate inline data properly during reflink.
    ocfs2: Move ocfs2_complete_reflink to the right place.
    ocfs2: Return -EINVAL when a device is not ocfs2.

    Linus Torvalds
     
  • Catch an overly long wait for an old, dying active object when we want to
    replace it with a new one. The probability is that all the slow-work threads
    are hogged, and the delete can't get a look in.

    What we do instead is:

    (1) if there's nothing in the slow work queue, we sleep until either the dying
    object has finished dying or there is something in the slow work queue
    behind which we can queue our object.

    (2) if there is something in the slow work queue, we return ETIMEDOUT to
    fscache_lookup_object(), which then puts us back on the slow work queue,
    presumably behind the deletion that we're blocked by. We are then
    deferred for a while until we work our way back through the queue -
    without blocking a slow-work thread unnecessarily.

    A backtrace similar to the following may appear in the log without this patch:

    INFO: task kslowd004:5711 blocked for more than 120 seconds.
    "echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.
    kslowd004 D 0000000000000000 0 5711 2 0x00000080
    ffff88000340bb80 0000000000000046 ffff88002550d000 0000000000000000
    ffff88002550d000 0000000000000007 ffff88000340bfd8 ffff88002550d2a8
    000000000000ddf0 00000000000118c0 00000000000118c0 ffff88002550d2a8
    Call Trace:
    [] ? trace_hardirqs_on+0xd/0xf
    [] ? cachefiles_wait_bit+0x0/0xd [cachefiles]
    [] cachefiles_wait_bit+0x9/0xd [cachefiles]
    [] __wait_on_bit+0x43/0x76
    [] ? ext3_xattr_get+0x1ec/0x270
    [] out_of_line_wait_on_bit+0x69/0x74
    [] ? cachefiles_wait_bit+0x0/0xd [cachefiles]
    [] ? wake_bit_function+0x0/0x2e
    [] cachefiles_mark_object_active+0x203/0x23b [cachefiles]
    [] cachefiles_walk_to_object+0x558/0x827 [cachefiles]
    [] cachefiles_lookup_object+0xac/0x12a [cachefiles]
    [] fscache_lookup_object+0x1c7/0x214 [fscache]
    [] fscache_object_state_machine+0xa5/0x52d [fscache]
    [] fscache_object_slow_work_execute+0x5f/0xa0 [fscache]
    [] slow_work_execute+0x18f/0x2d1
    [] slow_work_thread+0x1c5/0x308
    [] ? autoremove_wake_function+0x0/0x34
    [] ? slow_work_thread+0x0/0x308
    [] kthread+0x7a/0x82
    [] child_rip+0xa/0x20
    [] ? restore_args+0x0/0x30
    [] ? kthread+0x0/0x82
    [] ? child_rip+0x0/0x20
    1 lock held by kslowd004/5711:
    #0: (&sb->s_type->i_mutex_key#7/1){+.+.+.}, at: [] cachefiles_walk_to_object+0x1b3/0x827 [cachefiles]

    Signed-off-by: David Howells

    David Howells
     
  • Start processing an object's operations when that object moves into the DYING
    state as the object cannot be destroyed until all its outstanding operations
    have completed.

    Furthermore, make sure that read and allocation operations handle being woken
    up on a dead object. Such events are recorded in the Allocs.abt and
    Retrvls.abt statistics as viewable through /proc/fs/fscache/stats.

    The code for waiting for object activation for the read and allocation
    operations is also extracted into its own function as it is much the same in
    all cases, differing only in the stats incremented.

    Signed-off-by: David Howells

    David Howells
     
  • Handle netfs pages that the vmscan algorithm wants to evict from the pagecache
    under OOM conditions, but that are waiting for write to the cache. Under these
    conditions, vmscan calls the releasepage() function of the netfs, asking if a
    page can be discarded.

    The problem is typified by the following trace of a stuck process:

    kslowd005 D 0000000000000000 0 4253 2 0x00000080
    ffff88001b14f370 0000000000000046 ffff880020d0d000 0000000000000007
    0000000000000006 0000000000000001 ffff88001b14ffd8 ffff880020d0d2a8
    000000000000ddf0 00000000000118c0 00000000000118c0 ffff880020d0d2a8
    Call Trace:
    [] __fscache_wait_on_page_write+0x8b/0xa7 [fscache]
    [] ? autoremove_wake_function+0x0/0x34
    [] ? __fscache_check_page_write+0x63/0x70 [fscache]
    [] nfs_fscache_release_page+0x4e/0xc4 [nfs]
    [] nfs_release_page+0x3c/0x41 [nfs]
    [] try_to_release_page+0x32/0x3b
    [] shrink_page_list+0x316/0x4ac
    [] shrink_inactive_list+0x392/0x67c
    [] ? __mutex_unlock_slowpath+0x100/0x10b
    [] ? trace_hardirqs_on_caller+0x10c/0x130
    [] ? mutex_unlock+0x9/0xb
    [] shrink_list+0x8d/0x8f
    [] shrink_zone+0x278/0x33c
    [] ? ktime_get_ts+0xad/0xba
    [] try_to_free_pages+0x22e/0x392
    [] ? isolate_pages_global+0x0/0x212
    [] __alloc_pages_nodemask+0x3dc/0x5cf
    [] grab_cache_page_write_begin+0x65/0xaa
    [] ext3_write_begin+0x78/0x1eb
    [] generic_file_buffered_write+0x109/0x28c
    [] ? current_fs_time+0x22/0x29
    [] __generic_file_aio_write+0x350/0x385
    [] ? generic_file_aio_write+0x4a/0xae
    [] generic_file_aio_write+0x60/0xae
    [] do_sync_write+0xe3/0x120
    [] ? autoremove_wake_function+0x0/0x34
    [] ? __dentry_open+0x1a5/0x2b8
    [] ? dentry_open+0x82/0x89
    [] cachefiles_write_page+0x298/0x335 [cachefiles]
    [] fscache_write_op+0x178/0x2c2 [fscache]
    [] fscache_op_execute+0x7a/0xd1 [fscache]
    [] slow_work_execute+0x18f/0x2d1
    [] slow_work_thread+0x1c5/0x308
    [] ? autoremove_wake_function+0x0/0x34
    [] ? slow_work_thread+0x0/0x308
    [] kthread+0x7a/0x82
    [] child_rip+0xa/0x20
    [] ? restore_args+0x0/0x30
    [] ? tg_shares_up+0x171/0x227
    [] ? kthread+0x0/0x82
    [] ? child_rip+0x0/0x20

    In the above backtrace, the following is happening:

    (1) A page storage operation is being executed by a slow-work thread
    (fscache_write_op()).

    (2) FS-Cache farms the operation out to the cache to perform
    (cachefiles_write_page()).

    (3) CacheFiles is then calling Ext3 to perform the actual write, using Ext3's
    standard write (do_sync_write()) under KERNEL_DS directly from the netfs
    page.

    (4) However, for Ext3 to perform the write, it must allocate some memory, in
    particular, it must allocate at least one page cache page into which it
    can copy the data from the netfs page.

    (5) Under OOM conditions, the memory allocator can't immediately come up with
    a page, so it uses vmscan to find something to discard
    (try_to_free_pages()).

    (6) vmscan finds a clean netfs page it might be able to discard (possibly the
    one it's trying to write out).

    (7) The netfs is called to throw the page away (nfs_release_page()) - but it's
    called with __GFP_WAIT, so the netfs decides to wait for the store to
    complete (__fscache_wait_on_page_write()).

    (8) This blocks a slow-work processing thread - possibly against itself.

    The system ends up stuck because it can't write out any netfs pages to the
    cache without allocating more memory.

    To avoid this, we make FS-Cache cancel some writes that aren't in the middle of
    actually being performed. This means that some data won't make it into the
    cache this time. To support this, a new FS-Cache function is added
    fscache_maybe_release_page() that replaces what the netfs releasepage()
    functions used to do with respect to the cache.

    The decisions fscache_maybe_release_page() makes are counted and displayed
    through /proc/fs/fscache/stats on a line labelled "VmScan". There are four
    counters provided: "nos=N" - pages that weren't pending storage; "gon=N" -
    pages that were pending storage when we first looked, but weren't by the time
    we got the object lock; "bsy=N" - pages that we ignored as they were actively
    being written when we looked; and "can=N" - pages that we cancelled the storage
    of.

    What I'd really like to do is alter the behaviour of the cancellation
    heuristics, depending on how necessary it is to expel pages. If there are
    plenty of other pages that aren't waiting to be written to the cache that
    could be ejected first, then it would be nice to hold up on immediate
    cancellation of cache writes - but I don't see a way of doing that.

    Signed-off-by: David Howells

    David Howells
     
  • FS-Cache doesn't correctly handle the netfs requesting a read from the cache
    on an object that failed or was withdrawn by the cache. A trace similar to
    the following might be seen:

    CacheFiles: Lookup failed error -105
    [exe ] unexpected submission OP165afe [OBJ6cac OBJECT_LC_DYING]
    [exe ] objstate=OBJECT_LC_DYING [OBJECT_LC_DYING]
    [exe ] objflags=0
    [exe ] objevent=9 [fffffffffffffffb]
    [exe ] ops=0 inp=0 exc=0
    Pid: 6970, comm: exe Not tainted 2.6.32-rc6-cachefs #50
    Call Trace:
    [] fscache_submit_op+0x3ff/0x45a [fscache]
    [] __fscache_read_or_alloc_pages+0x187/0x3c4 [fscache]
    [] ? nfs_readpage_from_fscache_complete+0x0/0x66 [nfs]
    [] __nfs_readpages_from_fscache+0x7e/0x176 [nfs]
    [] ? __alloc_pages_nodemask+0x11c/0x5cf
    [] nfs_readpages+0x114/0x1d7 [nfs]
    [] __do_page_cache_readahead+0x15f/0x1ec
    [] ? __do_page_cache_readahead+0x73/0x1ec
    [] ra_submit+0x1c/0x20
    [] ondemand_readahead+0x227/0x23a
    [] page_cache_sync_readahead+0x17/0x19
    [] generic_file_aio_read+0x236/0x5a0
    [] nfs_file_read+0xe4/0xf3 [nfs]
    [] do_sync_read+0xe3/0x120
    [] ? _spin_unlock_irq+0x2b/0x31
    [] ? autoremove_wake_function+0x0/0x34
    [] ? selinux_file_permission+0x5d/0x10f
    [] ? thread_return+0x3e/0x101
    [] ? security_file_permission+0x11/0x13
    [] vfs_read+0xaa/0x16f
    [] ? trace_hardirqs_on_caller+0x10c/0x130
    [] sys_read+0x45/0x6c
    [] system_call_fastpath+0x16/0x1b

    The object state might also be OBJECT_DYING or OBJECT_WITHDRAWING.

    This should be handled by simply rejecting the new operation with ENOBUFS.
    There's no need to log an error for it. Events of this type now appear in the
    stats file under Ops:rej.

    Signed-off-by: David Howells

    David Howells
     
  • FS-Cache has two structs internally for keeping track of the internal state of
    a cached file: the fscache_cookie struct, which represents the netfs's state,
    and fscache_object struct, which represents the cache's state. Each has a
    pointer that points to the other (when both are in existence), and each has a
    spinlock for pointer maintenance.

    Since netfs operations approach these structures from the cookie side, they get
    the cookie lock first, then the object lock. Cache operations, on the other
    hand, approach from the object side, and get the object lock first. It is not
    then permitted for a cache operation to get the cookie lock whilst it is
    holding the object lock lest deadlock occur; instead, it must do one of two
    things:

    (1) increment the cookie usage counter, drop the object lock and then get both
    locks in order, or

    (2) simply hold the object lock as certain parts of the cookie may not be
    altered whilst the object lock is held.

    It is also not permitted to follow either pointer without holding the lock at
    the end you start with. To break the pointers between the cookie and the
    object, both locks must be held.

    fscache_write_op(), however, violates the locking rules: It attempts to get the
    cookie lock without (a) checking that the cookie pointer is a valid pointer,
    and (b) holding the object lock to protect the cookie pointer whilst it follows
    it. This is so that it can access the pending page store tree without
    interference from __fscache_write_page().

    This is fixed by splitting the cookie lock, such that the page store tracking
    tree is protected by its own lock, and checking that the cookie pointer is
    non-NULL before we attempt to follow it whilst holding the object lock.

    The new lock is subordinate to both the cookie lock and the object lock, and so
    should be taken after those.

    Signed-off-by: David Howells

    David Howells
     
  • Permit the operations to retrieve data from the cache or to allocate space in
    the cache for future writes to be interrupted whilst they're waiting for
    permission for the operation to proceed. Typically this wait occurs whilst the
    cache object is being looked up on disk in the background.

    If an interruption occurs, and the operation has not yet been given the
    go-ahead to run, the operation is dequeued and cancelled, and control returns
    to the read operation of the netfs routine with none of the requested pages
    having been read or in any way marked as known by the cache.

    This means that the initial wait is done interruptibly rather than
    uninterruptibly.

    In addition, extra stats values are made available to show the number of ops
    cancelled and the number of cache space allocations interrupted.

    Signed-off-by: David Howells

    David Howells
     
  • Count entries to and exits from cache operation table functions. Maintain
    these as a single counter that's added to or removed from as appropriate.

    Signed-off-by: David Howells

    David Howells
     
  • Allow the current state of all fscache objects to be dumped by doing:

    cat /proc/fs/fscache/objects

    By default, all objects and all fields will be shown. This can be restricted
    by adding a suitable key to one of the caller's keyrings (such as the session
    keyring):

    keyctl add user fscache:objlist "" @s

    The are:

    K Show hexdump of object key (don't show if not given)
    A Show hexdump of object aux data (don't show if not given)

    And paired restrictions:

    C Show objects that have a cookie
    c Show objects that don't have a cookie
    B Show objects that are busy
    b Show objects that aren't busy
    W Show objects that have pending writes
    w Show objects that don't have pending writes
    R Show objects that have outstanding reads
    r Show objects that don't have outstanding reads
    S Show objects that have slow work queued
    s Show objects that don't have slow work queued

    If neither side of a restriction pair is given, then both are implied. For
    example:

    keyctl add user fscache:objlist KB @s

    shows objects that are busy, and lists their object keys, but does not dump
    their auxiliary data. It also implies "CcWwRrSs", but as 'B' is given, 'b' is
    not implied.

    Signed-off-by: David Howells

    David Howells
     
  • Add a function to allow a requeueable work item to sleep till the thread
    processing it is needed by the slow-work facility to perform other work.

    Sometimes a work item can't progress immediately, but must wait for the
    completion of another work item that's currently being processed by another
    slow-work thread.

    In some circumstances, the waiting item could instead - theoretically - put
    itself back on the queue and yield its thread back to the slow-work facility,
    thus waiting till it gets processing time again before attempting to progress.
    This would allow other work items processing time on that thread.

    However, this only works if there is something on the queue for it to queue
    behind - otherwise it will just get a thread again immediately, and will end
    up cycling between the queue and the thread, eating up valuable CPU time.

    So, slow_work_sleep_till_thread_needed() is provided such that an item can put
    itself on a wait queue that will wake it up when the event it is actually
    interested in occurs, then call this function in lieu of calling schedule().

    This function will then sleep until either the item's event occurs or another
    work item appears on the queue. If another work item is queued, but the
    item's event hasn't occurred, then the work item should requeue itself and
    yield the thread back to the slow-work facility by returning.

    This can be used by CacheFiles for an object that is being created on one
    thread to wait for an object being deleted on another thread where there is
    nothing on the queue for the creation to go and wait behind. As soon as an
    item appears on the queue that could be given thread time instead, CacheFiles
    can stick the creating object back on the queue and return to the slow-work
    facility - assuming the object deletion didn't also complete.

    Signed-off-by: David Howells

    David Howells
     
  • Add a function (slow_work_is_queued()) to permit the owner of a work item to
    determine if the item is queued or not.

    The work item is counted as being queued if it is actually on the queue, not
    just if it is pending. If it is executing and pending, then it is not on the
    queue, but will rather be put back on the queue when execution finishes.

    This permits a caller to quickly work out if it may be able to put another,
    dependent work item on the queue behind it, or whether it will have to wait
    till that is finished.

    This can be used by CacheFiles to work out whether the creation a new object
    can be immediately deferred when it has to wait for an old object to be
    deleted, or whether a wait must take place. If a wait is necessary, then the
    slow-work thread can otherwise get blocked, preventing the deletion from
    taking place.

    Signed-off-by: David Howells

    David Howells
     
  • Allow the executing and queued work items to be viewed through a /proc file
    for debugging purposes. The contents look something like the following:

    THR PID ITEM ADDR FL MARK DESC
    === ===== ================ == ===== ==========
    0 3005 ffff880023f52348 a 952ms FSC: OBJ17d3: LOOK
    1 3006 ffff880024e33668 2 160ms FSC: OBJ17e5 OP60d3b: Write1/Store fl=2
    2 3165 ffff8800296dd180 a 424ms FSC: OBJ17e4: LOOK
    3 4089 ffff8800262c8d78 a 212ms FSC: OBJ17ea: CRTN
    4 4090 ffff88002792bed8 2 388ms FSC: OBJ17e8 OP60d36: Write1/Store fl=2
    5 4092 ffff88002a0ef308 2 388ms FSC: OBJ17e7 OP60d2e: Write1/Store fl=2
    6 4094 ffff88002abaf4b8 2 132ms FSC: OBJ17e2 OP60d4e: Write1/Store fl=2
    7 4095 ffff88002bb188e0 a 388ms FSC: OBJ17e9: CRTN
    vsq - ffff880023d99668 1 308ms FSC: OBJ17e0 OP60f91: Write1/EnQ fl=2
    vsq - ffff8800295d1740 1 212ms FSC: OBJ16be OP4d4b6: Write1/EnQ fl=2
    vsq - ffff880025ba3308 1 160ms FSC: OBJ179a OP58dec: Write1/EnQ fl=2
    vsq - ffff880024ec83e0 1 160ms FSC: OBJ17ae OP599f2: Write1/EnQ fl=2
    vsq - ffff880026618e00 1 160ms FSC: OBJ17e6 OP60d33: Write1/EnQ fl=2
    vsq - ffff880025a2a4b8 1 132ms FSC: OBJ16a2 OP4d583: Write1/EnQ fl=2
    vsq - ffff880023cbe6d8 9 212ms FSC: OBJ17eb: LOOK
    vsq - ffff880024d37590 9 212ms FSC: OBJ17ec: LOOK
    vsq - ffff880027746cb0 9 212ms FSC: OBJ17ed: LOOK
    vsq - ffff880024d37ae8 9 212ms FSC: OBJ17ee: LOOK
    vsq - ffff880024d37cb0 9 212ms FSC: OBJ17ef: LOOK
    vsq - ffff880025036550 9 212ms FSC: OBJ17f0: LOOK
    vsq - ffff8800250368e0 9 212ms FSC: OBJ17f1: LOOK
    vsq - ffff880025036aa8 9 212ms FSC: OBJ17f2: LOOK

    In the 'THR' column, executing items show the thread they're occupying and
    queued threads indicate which queue they're on. 'PID' shows the process ID of
    a slow-work thread that's executing something. 'FL' shows the work item flags.
    'MARK' indicates how long since an item was queued or began executing. Lastly,
    the 'DESC' column permits the owner of an item to give some information.

    Signed-off-by: David Howells

    David Howells
     
  • This adds support for starting slow work with a delay, similar
    to the functionality we have for workqueues.

    Signed-off-by: Jens Axboe
    Signed-off-by: David Howells

    Jens Axboe
     
  • Add support for cancellation of queued slow work and delayed slow work items.
    The cancellation functions will wait for items that are pending or undergoing
    execution to be discarded by the slow work facility.

    Attempting to enqueue work that is in the process of being cancelled will
    result in ECANCELED.

    Signed-off-by: Jens Axboe
    Signed-off-by: David Howells

    Jens Axboe
     
  • Make the ability for the slow-work facility to take references on a work item
    optional as not everyone requires this.

    Even the internal slow-work stubs them out, so those can be got rid of too.

    Signed-off-by: Jens Axboe
    Signed-off-by: David Howells

    Jens Axboe
     
  • Wait for outstanding slow work items belonging to a module to clear when
    unregistering that module as a user of the facility. This prevents the put_ref
    code of a work item from being taken away before it returns.

    Signed-off-by: David Howells

    David Howells
     

18 Nov, 2009

1 commit

  • …ux/kernel/git/josh/linux-misc

    * 'hostprogs-wmissing-prototypes' of git://git.kernel.org/pub/scm/linux/kernel/git/josh/linux-misc:
    Makefile: Add -Wmising-prototypes to HOSTCFLAGS
    oss: Mark loadhex static in hex2hex.c
    dtc: Mark various internal functions static
    dtc: Set "noinput" in the lexer to avoid an unused function
    drm: radeon: Mark several functions static in mkregtable
    arch/sparc/boot/*.c: Mark various internal functions static
    arch/powerpc/boot/addRamDisk.c: Mark several internal functions static
    arch/alpha/boot/tools/objstrip.c: Mark "usage" static
    Documentation/vm/page-types.c: Declare checked_open static
    genksyms: Mark is_reserved_word static
    kconfig: Mark various internal functions static
    kconfig: Make zconf.y work with current bison

    Linus Torvalds
     

16 Nov, 2009

1 commit


14 Nov, 2009

1 commit


10 Nov, 2009

1 commit


07 Nov, 2009

1 commit


06 Nov, 2009

3 commits


03 Nov, 2009

3 commits

  • This reverts commit d0646f7b636d067d715fab52a2ba9c6f0f46b0d7, as
    requested by Eric Sandeen.

    It can basically cause an ext4 filesystem to miss recovery (and thus get
    mounted with errors) if the journal checksum does not match.

    Quoth Eric:

    "My hand-wavy hunch about what is happening is that we're finding a
    bad checksum on the last partially-written transaction, which is
    not surprising, but if we have a wrapped log and we're doing the
    initial scan for head/tail, and we abort scanning on that bad
    checksum, then we are essentially running an unrecovered filesystem.

    But that's hand-wavy and I need to go look at the code.

    We lived without journal checksums on by default until now, and at
    this point they're doing more harm than good, so we should revert
    the default-changing commit until we can fix it and do some good
    power-fail testing with the fixes in place."

    See

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

    for all the gory details.

    Requested-by: Eric Sandeen
    Cc: Theodore Tso
    Cc: Alexey Fisher
    Cc: Maxim Levitsky
    Cc: Aneesh Kumar K.V
    Cc: Mathias Burén
    Signed-off-by: Linus Torvalds

    Linus Torvalds
     
  • * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound-2.6:
    ALSA: hda - Don't check invalid HP pin
    ALSA: dummy - Fix descriptions of pcm_substreams parameter
    ALSA: pcmcia: use dynamic debug infrastructure, deprecate CS_CHECK (sound)
    ALSA: hda: Use quirk mask for Dell Inspiron Mini9/Vostro A90 using ALC268
    sound: via82xx: deactivate DXS controls of inactive streams
    ALSA: snd-usb-caiaq: Bump version number to 1.3.20
    ALSA: snd-usb-caiaq: Lock on stream start/unpause
    ALSA: snd-usb-caiaq: Missing lock around use of buffer positions
    ALSA: sound/parisc: Move dereference after NULL test
    ALSA: sound: Move dereference after NULL test and drop unnecessary NULL tests
    ALSA: hda_intel: Add the Linux device ID for NVIDIA HDA controller
    ALSA: pcsp - Fix nforce workaround
    ALSA: SND_CS5535AUDIO: Remove the X86 platform dependency
    ASoC: Amstrad Delta: add info about the line discipline requirement to Kconfig help text
    ASoC: Fix possible codec_dai->ops NULL pointer problems
    ALSA: hda - Fix capture source checks for ALC662/663 codecs
    ASoC: Serialize access to dapm_power_widgets()

    Linus Torvalds
     
  • …nel/git/tip/linux-2.6-tip

    * 'tracing-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip:
    tracing: Remove cpu arg from the rb_time_stamp() function
    tracing: Fix comment typo and documentation example
    tracing: Fix trace_seq_printf() return value
    tracing: Update *ppos instead of filp->f_pos

    Linus Torvalds
     

02 Nov, 2009

1 commit


31 Oct, 2009

7 commits


29 Oct, 2009

2 commits