28 Mar, 2009

2 commits

  • Due to poor thermal design or Linux driving hardware outside its thermal
    envelope, some systems will reach critical temperature and shut down
    under high load. This patch adds support for forcing a polling-based
    passive trip point if the firmware doesn't provide one. The assumption
    is made that the processor is the most practical means to reduce the
    dynamic heat generation, so hitting the passive thermal limit will cause
    the CPU to be throttled until the temperature stabalises around the
    defined value.

    UI is provided via a "passive" sysfs entry in the thermal zone
    directory. It accepts a decimal value in millidegrees celsius, or "0" to
    disable the functionality. Default behaviour is for this functionality
    to be disabled.

    Signed-off-by: Matthew Garrett
    Signed-off-by: Len Brown

    Matthew Garrett
     
  • > drivers/acpi/thermal.c: In function 'thermal_notify':
    > drivers/acpi/thermal.c:768: error: 'struct device' has no member named 'bus_id'
    >
    > Caused by commit b1569e99c795bf83b4ddf41c4f1c42761ab7f75e ("ACPI: move
    > thermal trip handling to generic thermal layer") interacting with commit
    > d4a078fca590911cdf87a8eaffee1b6e643c2558 ("driver core: get rid of struct
    > device's bus_id string array").
    >

    Signed-off-by: Stephen Rothwell
    Signed-off-by: Len Brown

    Stephen Rothwell
     

21 Feb, 2009

1 commit


20 Feb, 2009

1 commit


14 Feb, 2009

3 commits

  • Linus Torvalds
     
  • * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound-2.6:
    ASoC: Only register AC97 bus if it's not done already
    ALSA: hda - Add snd_hda_multi_out_dig_cleanup()
    ALSA: hda - Add missing terminator in slave dig-out array
    ALSA: hda - Change HP dv7 (103c:30f4) quirk from hp-m4 to hp-dv5 model
    ALSA: hda - Register (new) devices at reconfig
    ALSA: mtpav - Fix initial value for input hwport
    ALSA: hda - add id for Intel IbexPeak integrated HDMI codec
    ALSA: hda - compute checksum in HDMI audio infoframe
    ALSA: hda - enable HDMI audio pin out at module loading time
    ALSA: hda - allow multi-channel HDMI audio playback when ELD is not present
    ASoC: Update SDP3430 machine driver for snd_soc_card
    ALSA: hda - Add quirk for Asus z37e (1043:8284)
    sound: Remove OSSlib stuff from linux/soundcard.h
    ASoC: WM8990: Fix kcontrol's private value use in put callback
    ASoC: TLV320AIC3X: Fix kcontrol's private value use in put callback

    Linus Torvalds
     
  • uids in namespaces other than init don't get a sysfs entry.

    For those in the init namespace, while we're waiting to remove
    the sysfs entry for the uid the uid is still hashed, and
    alloc_uid() may re-grab that uid without getting a new
    reference to the user_ns, which we've already put in free_user
    before scheduling remove_user_sysfs_dir().

    Reported-and-tested-by: KOSAKI Motohiro
    Signed-off-by: Serge E. Hallyn
    Acked-by: David Howells
    Tested-by: Ingo Molnar
    Signed-off-by: Linus Torvalds

    Serge E. Hallyn
     

13 Feb, 2009

32 commits

  • Takashi Iwai
     
  • Takashi Iwai
     
  • Takashi Iwai
     
  • Takashi Iwai
     
  • ASoC supports both explicit codec drivers for AC97 devices and a simple
    driver which uses the standard ALSA AC97 framework for codec support.
    When used with the generic AC97 codec support that will provide the
    ad hoc AC97 device for drivers like touchscreens to attach to so the
    core shouldn't do so.

    Reported-by: Manuel Lauss
    Signed-off-by: Mark Brown

    Mark Brown
     
  • Added the helper function snd_hda_multi_out_dig_cleanup() to clean up
    the digital outputs with multi setup. This call is needed in cases
    the codec supports multiple digital outputs as slaves. Otherwise the
    slave widgets aren't properly cleaned up.

    For a single digital output (e.g. in patch_conexant.c), this call isn't
    needed.

    Signed-off-by: Takashi Iwai

    Takashi Iwai
     
  • Added the missing terminator for ad1989b_slave_dig_outs[].

    Cc:
    Signed-off-by: Takashi Iwai

    Takashi Iwai
     
  • Change HP dv7 quirk: although reported to work with hp-m4 model
    (https://bugzilla.novell.com/show_bug.cgi?id=445321), the original
    report doesn't contain info about testing of internal microphone.

    Recently I received a report about internal mic not working
    (https://qa.mandriva.com/show_bug.cgi?id=44855#c193), this must be
    related with the forced line in on pin 0x0e done with hp-m4 model. Thus
    change the current quirk from STAC_HP_M4 to STAC_HP_DV5, later reported
    to be fixed on a provided kernel with this change
    (https://qa.mandriva.com/show_bug.cgi?id=44855#c196).

    Signed-off-by: Herton Ronaldo Krzesinski
    Signed-off-by: Takashi Iwai

    Herton Ronaldo Krzesinski
     
  • * git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6: (32 commits)
    wimax: fix oops in wimax_dev_get_by_genl_info() when looking up non-wimax iface
    net: 4 bytes kernel memory disclosure in SO_BSDCOMPAT gsopt try #2
    netxen: fix compile waring "label ‘set_32_bit_mask’ defined but not used" on IA64 platform
    bnx2: Update version to 1.9.2 and copyright.
    bnx2: Fix jumbo frames error handling.
    bnx2: Update 5709 firmware.
    bnx2: Update 5706/5708 firmware.
    3c505: do not set pcb->data.raw beyond its size
    Documentation/connector/cn_test.c: don't use gfp_any()
    net: don't use in_atomic() in gfp_any()
    IRDA: cnt is off by 1
    netxen: remove pcie workaround
    sun3: print when lance_open() fails
    qlge: bugfix: Add missing rx buf clean index on early exit.
    qlge: bugfix: Fix RX scaling values.
    qlge: bugfix: Fix TSO breakage.
    qlge: bugfix: Add missing dev_kfree_skb_any() call.
    qlge: bugfix: Add missing put_page() call.
    qlge: bugfix: Fix fatal error recovery hang.
    qlge: bugfix: Use netif_receive_skb() and vlan_hwaccel_receive_skb().
    ...

    Linus Torvalds
     
  • When a non-wimax interface is looked up by the stack, a bad pointer is
    returned when the looked-up interface is not found in the list (of
    registered WiMAX interfaces). This causes an oops in the caller when
    trying to use the pointer.

    Fix by properly setting the pointer to NULL if we don't exit from the
    list_for_each() with a found entry.

    Signed-off-by: Inaky Perez-Gonzalez
    Signed-off-by: David S. Miller

    Inaky Perez-Gonzalez
     
  • In function sock_getsockopt() located in net/core/sock.c, optval v.val
    is not correctly initialized and directly returned in userland in case
    we have SO_BSDCOMPAT option set.

    This dummy code should trigger the bug:

    int main(void)
    {
    unsigned char buf[4] = { 0, 0, 0, 0 };
    int len;
    int sock;
    sock = socket(33, 2, 2);
    getsockopt(sock, 1, SO_BSDCOMPAT, &buf, &len);
    printf("%x%x%x%x\n", buf[0], buf[1], buf[2], buf[3]);
    close(sock);
    }

    Here is a patch that fix this bug by initalizing v.val just after its
    declaration.

    Signed-off-by: Clément Lecigne
    Signed-off-by: David S. Miller

    Clément Lecigne
     
  • When compile the latest kernel on IA64 platform,I got a warning:
    drivers/net/netxen/netxen_nic_main.c:203: warning: label ‘set_32_bit_mask’
    defined but not used

    We do not need label ‘set_32_bit_mask’ on IA64 platform,So move it to #else.

    Signed-off-by: Yang Hongyang
    Signed-off-by: David S. Miller

    Yang Hongyang
     
  • Signed-off-by: Michael Chan
    Signed-off-by: David S. Miller

    Michael Chan
     
  • If errors are reported on a frame descriptor, we need to
    account for the buffer pages that may have been used for this
    error packet and recycle them. Otherwise, we may get the wrong
    pages for the next packet.

    Signed-off-by: Michael Chan
    Signed-off-by: Matt Carlson
    Signed-off-by: Benjamin Li
    Signed-off-by: David S. Miller

    Michael Chan
     
  • New firmware fixes a data corruption issue when receiving and
    placing jumbo frames into host buffers. In some cases, the
    buffer descriptor is not updated correctly and this will lead
    to the driver linking the wrong number of pages into the SKB.

    Signed-off-by: Michael Chan
    Signed-off-by: David S. Miller

    Michael Chan
     
  • New firmware fixes a data corruption issue when receiving and
    placing jumbo frames into host buffers. In some cases, the
    buffer descriptor is not updated correctly and this will lead
    to the driver linking the wrong number of pages into the SKB.

    Signed-off-by: Michael Chan
    Signed-off-by: David S. Miller

    Michael Chan
     
  • Ensure that we do not set pcb->data.raw beyond its size, print an error message
    and return false if we attempt to. A timout message was printed one too early.

    Signed-off-by: Roel Kluin
    Signed-off-by: David S. Miller

    Roel Kluin
     
  • cn_test_timer_func() is a timer handler and can never use GFP_KERNEL -
    there's no point in using gfp_any() here.

    Also, use setup_timer().

    Signed-off-by: Andrew Morton
    Signed-off-by: David S. Miller

    Andrew Morton
     
  • The problem is that in_atomic() will return false inside spinlocks if
    CONFIG_PREEMPT=n. This will lead to deadlockable GFP_KERNEL allocations
    from spinlocked regions.

    Secondly, if CONFIG_PREEMPT=y, this bug solves itself because networking
    will instead use GFP_ATOMIC from this callsite. Hence we won't get the
    might_sleep() debugging warnings which would have informed us of the buggy
    callsites.

    Solve both these problems by switching to in_interrupt(). Now, if someone
    runs a gfp_any() allocation from inside spinlock we will get the warning
    if CONFIG_PREEMPT=y.

    I reviewed all callsites and most of them were too complex for my little
    brain and none of them documented their interface requirements. I have no
    idea what this patch will do.

    Signed-off-by: Andrew Morton
    Signed-off-by: David S. Miller

    Andrew Morton
     
  • If no prior break occurs, cnt reaches 101 after the loop, so we are still able
    to change speed when cnt has become 100.

    Signed-off-by: Roel Kluin
    Signed-off-by: David S. Miller

    Roel Kluin
     
  • Remove workaround for pcie bug in early revisions of NX3031
    (rev 41 or earlier). This is taken care of during firmware init.

    The workaround required writing pcie config reg of every
    pcie function on a card, not all of which are enabled.

    Signed-off-by: Dhananjay Phadke
    Signed-off-by: David S. Miller

    Dhananjay Phadke
     
  • With while (--i > 0) { ... } i reaches 0; print when lance_open() fails

    Signed-off-by: Roel Kluin
    Signed-off-by: David S. Miller

    Roel Kluin
     
  • The large receive buffer queue is not properly tracking the current
    index in the case where an early exit occurs. This can happen when a
    page alloc or dma mapping fails. If this occurs the queue will get
    out of sync and invalid indexes can be written to the hardware.

    Signed-off-by: Ron Mercer
    Signed-off-by: David S. Miller

    Ron Mercer
     
  • Receive packets were only scaling across 2 of the receive queues. The
    value was hardcoded to 2 instead of being based on how many rx queues
    were running.

    Signed-off-by: Ron Mercer
    Signed-off-by: David S. Miller

    Ron Mercer
     
  • Moved the buffer mapping to a point after TSO logic has modified the
    iph->check field. We were seeing stale data on the PCIe bus.

    Signed-off-by: Ron Mercer
    Signed-off-by: David S. Miller

    Ron Mercer
     
  • We put the skb back if we can't get mapping for it. We don't
    want unmapped buffers on our receive buffer queue.

    Signed-off-by: Ron Mercer
    Signed-off-by: David S. Miller

    Ron Mercer
     
  • We put the page back if we can't get mapping for it. We don't
    want unmapped buffers on our receive buffer queue.

    Signed-off-by: Ron Mercer
    Signed-off-by: David S. Miller

    Ron Mercer
     
  • Signed-off-by: Ron Mercer
    Signed-off-by: David S. Miller

    Ron Mercer
     
  • Replace calls to vlan_hwaccel_rx() and netif_rx().
    Thanks to Dave Miller for pointing out the the driver was making
    the wrong upcall for passing packets into the stack.

    Signed-off-by: Ron Mercer
    Signed-off-by: David S. Miller

    Ron Mercer
     
  • With while (limit--) { ... } limit reaches -1, so 0 means success.

    Signed-off-by: Roel Kluin
    Acked-by: Michael Chan
    Signed-off-by: David S. Miller

    Roel Kluin
     
  • * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/penberg/slab-2.6:
    mm: Export symbol ksize()

    Linus Torvalds
     
  • A bug was introduced into write_cache_pages cyclic writeout by commit
    31a12666d8f0c22235297e1c1575f82061480029 ("mm: write_cache_pages cyclic
    fix"). The intention (and comments) is that we should cycle back and
    look for more dirty pages at the beginning of the file if there is no
    more work to be done.

    But the !done condition was dropped from the test. This means that any
    time the page writeout loop breaks (eg. due to nr_to_write == 0), we
    will set index to 0, then goto again. This will set done_index to
    index, then find done is set, so will proceed to the end of the
    function. When updating mapping->writeback_index for cyclic writeout,
    we now use done_index == 0, so we're always cycling back to 0.

    This seemed to be causing random mmap writes (slapadd and iozone) to
    start writing more pages from the LRU and writeout would slowdown, and
    caused bugzilla entry

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

    about Berkeley DB slowing down dramatically.

    With this patch, iozone random write performance is increased nearly
    5x on my system (iozone -B -r 4k -s 64k -s 512m -s 1200m on ext2).

    Signed-off-by: Nick Piggin
    Reported-and-tested-by: Jan Kara
    Signed-off-by: Linus Torvalds

    Nick Piggin
     

12 Feb, 2009

1 commit

  • Commit 7b2cd92adc5430b0c1adeb120971852b4ea1ab08 ("crypto: api - Fix
    zeroing on free") added modular user of ksize(). Export that to fix
    crypto.ko compilation.

    Cc: Herbert Xu
    Signed-off-by: Kirill A. Shutemov
    Signed-off-by: Pekka Enberg

    Kirill A. Shutemov