22 Jan, 2011

4 commits

  • …/linux-2.6 into perf/urgent

    Ingo Molnar
     
  • In theory, almost every user of task->child->perf_event_ctxp[]
    is wrong. find_get_context() can install the new context at any
    moment, we need read_barrier_depends().

    dbe08d82ce3967ccdf459f7951d02589cf967300 "perf: Fix
    find_get_context() vs perf_event_exit_task() race" added
    rcu_dereference() into perf_event_exit_task_context() to make
    the precedent, but this makes __rcu_dereference_check() unhappy.
    Use rcu_dereference_raw() to shut up the warning.

    Reported-by: Ingo Molnar
    Signed-off-by: Oleg Nesterov
    Cc: acme@redhat.com
    Cc: paulus@samba.org
    Cc: stern@rowland.harvard.edu
    Cc: a.p.zijlstra@chello.nl
    Cc: fweisbec@gmail.com
    Cc: roland@redhat.com
    Cc: prasad@linux.vnet.ibm.com
    Cc: Paul E. McKenney
    LKML-Reference:
    Signed-off-by: Ingo Molnar

    Oleg Nesterov
     
  • When some of CPUs are offline:

    # cat /sys/devices/system/cpu/online
    0,6-31

    perf test will fail on #3 testcase:

    3: detect open syscall event on all cpus:
    --- start ---
    perf_evsel__read_on_cpu: expected to intercept 111 calls on cpu 0, got 681
    perf_evsel__read_on_cpu: expected to intercept 112 calls on cpu 1, got 117
    perf_evsel__read_on_cpu: expected to intercept 113 calls on cpu 2, got 118
    perf_evsel__read_on_cpu: expected to intercept 114 calls on cpu 3, got 119
    perf_evsel__read_on_cpu: expected to intercept 115 calls on cpu 4, got 120
    perf_evsel__read_on_cpu: expected to intercept 116 calls on cpu 5, got 121
    perf_evsel__read_on_cpu: expected to intercept 117 calls on cpu 6, got 122
    perf_evsel__read_on_cpu: expected to intercept 118 calls on cpu 7, got 123
    perf_evsel__read_on_cpu: expected to intercept 119 calls on cpu 8, got 124
    perf_evsel__read_on_cpu: expected to intercept 120 calls on cpu 9, got 125
    perf_evsel__read_on_cpu: expected to intercept 121 calls on cpu 10, got 126
    ....

    This patch try to use 'cpus->map[cpu]' when setting cpu affinity, and
    will check the return code of sched_setaffinity()

    LKML-Reference:
    Signed-off-by: Han Pingtian
    Signed-off-by: Arnaldo Carvalho de Melo

    Han Pingtian
     
  • In ARM's Thumb mode the bottom bit of the symbol address is set to mark
    the function as Thumb; the instructions are in reality 2 or 4 byte on 2
    byte alignments, and when the +1 address is used in annotate it causes
    objdump to disassemble invalid instructions.

    The patch removes that bottom bit during symbol loading.

    Many thinks to Dave Martin for comments on an initial version of the
    patch.

    (For reference this corresponds to this bug
    https://bugs.launchpad.net/linux-linaro/+bug/677547 )

    Cc: Ingo Molnar
    Cc: Dave Martin
    LKML-Reference:
    Signed-off-by: Dr. David Alan Gilbert
    Signed-off-by: Arnaldo Carvalho de Melo

    Dr. David Alan Gilbert
     

21 Jan, 2011

1 commit

  • Lockdep spotted:

    loop_1b_instruc/1899 is trying to acquire lock:
    (event_mutex){+.+.+.}, at: [] perf_trace_init+0x3b/0x2f7

    but task is already holding lock:
    (&ctx->mutex){+.+.+.}, at: [] perf_event_init_context+0xc0/0x218

    which lock already depends on the new lock.

    the existing dependency chain (in reverse order) is:

    -> #3 (&ctx->mutex){+.+.+.}:
    -> #2 (cpu_hotplug.lock){+.+.+.}:
    -> #1 (module_mutex){+.+...}:
    -> #0 (event_mutex){+.+.+.}:

    But because the deadlock would be cpuhotplug (cpu-event) vs fork
    (task-event) it cannot, in fact, happen. We can annotate this by giving the
    perf_event_context used for the cpuctx a different lock class from those
    used by tasks.

    Signed-off-by: Peter Zijlstra
    LKML-Reference:
    Signed-off-by: Ingo Molnar

    Peter Zijlstra
     

20 Jan, 2011

3 commits

  • When fixing the frequency calculations for perf on powerpc I
    forgot to fix the FSL version.

    If we dont set event->hw.last_period the frequency to period
    calculations in perf go haywire and we continually
    throttle/unthrottle the PMU.

    Signed-off-by: Anton Blanchard
    Acked-by: Benjamin Herrenschmidt
    Cc: Scott Wood
    Cc: Paul Mackerras
    Cc: Arnaldo Carvalho de Melo
    Cc: linuxppc-dev@lists.ozlabs.org
    Cc: Peter Zijlstra
    LKML-Reference:
    Signed-off-by: Ingo Molnar

    Anton Blanchard
     
  • perf_event_init_task() should clear child->perf_event_ctxp[]
    before anything else. Otherwise, if
    perf_event_init_context(perf_hw_context) fails,
    perf_event_free_task() can free perf_event_ctxp[perf_sw_context]
    copied from parent->perf_event_ctxp[] by dup_task_struct().

    Also move the initialization of perf_event_mutex and
    perf_event_list from perf_event_init_context() to
    perf_event_init_context().

    Signed-off-by: Oleg Nesterov
    Acked-by: Peter Zijlstra
    Cc: Alan Stern
    Cc: Arnaldo Carvalho de Melo
    Cc: Frederic Weisbecker
    Cc: Paul Mackerras
    Cc: Prasad
    Cc: Roland McGrath
    LKML-Reference:
    Signed-off-by: Ingo Molnar

    Oleg Nesterov
     
  • find_get_context() must not install the new perf_event_context
    if the task has already passed perf_event_exit_task().

    If nothing else, this means the memory leak. Initially
    ctx->refcount == 2, it is supposed that
    perf_event_exit_task_context() should participate and do the
    necessary put_ctx().

    find_lively_task_by_vpid() checks PF_EXITING but this buys
    nothing, by the time we call find_get_context() this task can be
    already dead. To the point, cmpxchg() can succeed when the task
    has already done the last schedule().

    Change find_get_context() to populate task->perf_event_ctxp[]
    under task->perf_event_mutex, this way we can trust PF_EXITING
    because perf_event_exit_task() takes the same mutex.

    Also, change perf_event_exit_task_context() to use
    rcu_dereference(). Probably this is not strictly needed, but
    with or without this change find_get_context() can race with
    setup_new_exec()->perf_event_exit_task(), rcu_dereference()
    looks better.

    Signed-off-by: Oleg Nesterov
    Acked-by: Peter Zijlstra
    Cc: Alan Stern
    Cc: Arnaldo Carvalho de Melo
    Cc: Frederic Weisbecker
    Cc: Paul Mackerras
    Cc: Prasad
    Cc: Roland McGrath
    LKML-Reference:
    Signed-off-by: Ingo Molnar

    Oleg Nesterov
     

19 Jan, 2011

32 commits

  • Linus Torvalds
     
  • * 'hwmon-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/groeck/staging:
    hwmon: (lm93) Add support for LM94

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

    * 'perf-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip:
    perf: Validate cpu early in perf_event_alloc()
    perf: Find_get_context: fix the per-cpu-counter check
    perf: Fix contexted inheritance

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

    * 'x86-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip:
    x86: Clear irqstack thread_info
    x86: Make relocatable kernel work with new binutils

    Linus Torvalds
     
  • * 'upstream' of git://git.linux-mips.org/pub/scm/upstream-linus: (26 commits)
    MIPS: Malta: enable Cirrus FB console
    MIPS: add CONFIG_VIRTUALIZATION for virtio support
    MIPS: Implement __read_mostly
    MIPS: ath79: add common WMAC device for AR913X based boards
    MIPS: ath79: Add initial support for the Atheros AP81 reference board
    MIPS: ath79: add common SPI controller device
    SPI: Add SPI controller driver for the Atheros AR71XX/AR724X/AR913X SoCs
    MIPS: ath79: add common GPIO buttons device
    MIPS: ath79: add common watchdog device
    MIPS: ath79: add common GPIO LEDs device
    MIPS: ath79: add initial support for the Atheros PB44 reference board
    MIPS: ath79: utilize the MIPS multi-machine support
    MIPS: ath79: add GPIOLIB support
    MIPS: Add initial support for the Atheros AR71XX/AR724X/AR931X SoCs
    MIPS: jump label: Add MIPS support.
    MIPS: Use WARN() in uasm for better diagnostics.
    MIPS: Optimize TLB handlers for Octeon CPUs
    MIPS: Add LDX and LWX instructions to uasm.
    MIPS: Use BBIT instructions in TLB handlers
    MIPS: Declare uasm bbit0 and bbit1 functions.
    ...

    Linus Torvalds
     
  • This patch adds basic support for LM94 to the LM93 driver. LM94 specific
    sensors and features are not supported.

    Signed-off-by: Guenter Roeck
    Acked-by: Jean Delvare

    Guenter Roeck
     
  • Starting from perf_event_alloc()->perf_init_event(), the kernel
    assumes that event->cpu is either -1 or the valid CPU number.

    Change perf_event_alloc() to validate this argument early. This
    also means we can remove the similar check in
    find_get_context().

    Signed-off-by: Oleg Nesterov
    Acked-by: Peter Zijlstra
    Cc: Alan Stern
    Cc: Arnaldo Carvalho de Melo
    Cc: Frederic Weisbecker
    Cc: Paul Mackerras
    Cc: Prasad
    Cc: Roland McGrath
    Cc: gregkh@suse.de
    Cc: stable@kernel.org
    LKML-Reference:
    Signed-off-by: Ingo Molnar

    Oleg Nesterov
     
  • If task == NULL, find_get_context() should always check that cpu
    is correct.

    Afaics, the bug was introduced by 38a81da2 "perf events: Clean
    up pid passing", but even before that commit "&& cpu != -1" was
    not exactly right, -ESRCH from find_task_by_vpid() is not
    accurate.

    Signed-off-by: Oleg Nesterov
    Acked-by: Peter Zijlstra
    Cc: Alan Stern
    Cc: Arnaldo Carvalho de Melo
    Cc: Frederic Weisbecker
    Cc: Paul Mackerras
    Cc: Prasad
    Cc: Roland McGrath
    Cc: gregkh@suse.de
    Cc: stable@kernel.org
    LKML-Reference:
    Signed-off-by: Ingo Molnar

    Oleg Nesterov
     
  • While most users of a physical Malta board are using the serial port
    as the console, a lot of QEMU users would prefer to interact with a
    graphical console. Enable the Cirrus FB support in the Malta default
    configuration to make that possible. Note that the default console will
    still be the serial port, users have to pass "console=tty0" to the
    kernel to use the Cirrus FB.

    Signed-off-by: Aurelien Jarno
    To: linux-mips@linux-mips.org
    Patchwork: https://patchwork.linux-mips.org/patch/2001/
    Signed-off-by: Ralf Baechle

    Aurelien Jarno
     
  • Add CONFIG_VIRTUALIZATION to the MIPS architecture and include the
    the virtio code there. Used to enable the virtio drivers under QEMU.

    Signed-off-by: Aurelien Jarno
    To: linux-mips@linux-mips.org
    Patchwork: https://patchwork.linux-mips.org/patch/2002/
    Signed-off-by: Ralf Baechle

    Aurelien Jarno
     
  • Just do what everyone else is doing by placing __read_mostly things in
    the .data.read_mostly section.

    mips_io_port_base can not be read-only (const) and writable
    (__read_mostly) at the same time. One of them has to go, so I chose
    to eliminate the __read_mostly. It will still get stuck in a portion
    of memory that is not adjacent to things that are written, and thus
    not be on a dirty cache line, for whatever that is worth.

    Signed-off-by: David Daney
    To: linux-mips@linux-mips.org
    Patchwork: http://patchwork.linux-mips.org/patch/1702/
    Signed-off-by: Ralf Baechle

    David Daney
     
  • Add common platform_device and helper code to make the registration
    of the built-in wireless MAC easier on the Atheros AR9130/AR9132
    based boards. Also register the WMAC device on the AR81 board.

    Signed-off-by: Gabor Juhos
    Cc: linux-mips@linux-mips.org
    Cc: Imre Kaloz ,
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Cc: Kathy Giori
    Patchwork: https://patchwork.linux-mips.org/patch/1962/
    Signed-off-by: Ralf Baechle

    Gabor Juhos
     
  • Signed-off-by: Gabor Juhos
    Signed-off-by: Imre Kaloz
    Cc: linux-mips@linux-mips.org
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Cc: Kathy Giori
    Patchwork: https://patchwork.linux-mips.org/patch/1952/
    Signed-off-by: Ralf Baechle

    Gabor Juhos
     
  • Several boards are using the built-in SPI controller of the
    AR71XX/AR724X/AR913X SoCs. This patch adds common platform_device
    and helper code to register it. Additionally, the patch registers
    the SPI bus on the PB44 board.

    Signed-off-by: Gabor Juhos
    Cc: linux-mips@linux-mips.org
    Cc: Imre Kaloz
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Cc: Kathy Giori
    Patchwork: https://patchwork.linux-mips.org/patch/1956/
    Signed-off-by: Ralf Baechle

    Gabor Juhos
     
  • The Atheros AR71XX/AR724X/AR913X SoCs have a built-in SPI controller. This
    patch implements a driver for that.

    Signed-off-by: Gabor Juhos
    Cc: David Brownell
    Cc: spi-devel-general@lists.sourceforge.net
    Acked-by: Grant Likely
    Cc: linux-mips@linux-mips.org
    Cc: Imre Kaloz
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Cc: Kathy Giori
    Patchwork: https://patchwork.linux-mips.org/patch/1960/
    Signed-off-by: Ralf Baechle

    Gabor Juhos
     
  • Almost all boards have one or more push buttons connected to GPIO lines.
    This patch adds common code to register a platform_device for them.

    The patch also adds support for the buttons on the PB44 board.

    Signed-off-by: Gabor Juhos
    Signed-off-by: Imre Kaloz
    Cc: linux-mips@linux-mips.org
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Cc: Kathy Giori
    Patchwork: https://patchwork.linux-mips.org/patch/1954/
    Signed-off-by: Ralf Baechle

    Gabor Juhos
     
  • All supported SoCs have a built-in hardware watchdog driver. This patch
    registers a platform_device for that to make it usable.

    Signed-off-by: Gabor Juhos
    Signed-off-by: Imre Kaloz
    Cc: linux-mips@linux-mips.org
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Cc: Kathy Giori
    Patchwork: https://patchwork.linux-mips.org/patch/1955/
    Signed-off-by: Ralf Baechle

    Gabor Juhos
     
  • Almost all boards have one or more LEDs connected to GPIO lines. This
    patch adds common code to register a platform_device for them.

    The patch also adds support for the LEDs on the PB44 board.

    Signed-off-by: Gabor Juhos
    Signed-off-by: Imre Kaloz
    Cc: linux-mips@linux-mips.org
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Cc: Kathy Giori
    Patchwork: https://patchwork.linux-mips.org/patch/1953/
    Signed-off-by: Ralf Baechle

    Gabor Juhos
     
  • Signed-off-by: Gabor Juhos
    Cc: Imre Kaloz
    Cc: linux-mips@linux-mips.org
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Cc: Kathy Giori
    Patchwork: https://patchwork.linux-mips.org/patch/1950/
    Signed-off-by: Ralf Baechle

    Gabor Juhos
     
  • Signed-off-by: Gabor Juhos
    Cc: Imre Kaloz
    Cc: linux-mips@linux-mips.org
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Cc: Kathy Giori
    Patchwork: https://patchwork.linux-mips.org/patch/1949/
    Signed-off-by: Ralf Baechle

    Gabor Juhos
     
  • This patch implements generic GPIO routines for the built-in
    GPIO controllers of the Atheros AR71XX/AR724X/AR913X SoCs.

    Signed-off-by: Gabor Juhos
    Signed-off-by: Imre Kaloz
    Cc: David Brownell
    Cc: linux-mips@linux-mips.org
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Cc: Kathy Giori
    Patchwork: https://patchwork.linux-mips.org/patch/1948/
    Signed-off-by: Ralf Baechle

    Gabor Juhos
     
  • This patch adds initial support for various Atheros SoCs based on the
    MIPS 24Kc core. The following models are supported at the moment:

    - AR7130
    - AR7141
    - AR7161
    - AR9130
    - AR9132
    - AR7240
    - AR7241
    - AR7242

    The current patch contains minimal support only, but the resulting
    kernel can boot into user-space with using of an initramfs image on
    various boards which are using these SoCs. Support for more built-in
    devices and individual boards will be implemented in further patches.

    Signed-off-by: Gabor Juhos
    Signed-off-by: Imre Kaloz
    Cc: linux-mips@linux-mips.org
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Cc: Kathy Giori
    Patchwork: https://patchwork.linux-mips.org/patch/1947/
    Signed-off-by: Ralf Baechle

    Gabor Juhos
     
  • In order not to be left behind, we add jump label support for MIPS.

    Tested on 64-bit big endian (Octeon), and 32-bit little endian
    (malta/qemu).

    Signed-off-by: David Daney
    To: linux-mips@linux-mips.org
    Cc: Steven Rostedt
    Cc: Jason Baron
    Patchwork: https://patchwork.linux-mips.org/patch/1923/
    Signed-off-by: Ralf Baechle

    David Daney
     
  • On the off chance that uasm ever warns about overflow, there is no way
    to know what the offending instruction is.

    Change the printks to WARNs, so we can get a nice stack trace. It has
    the added benefit of being much more noticeable than the short single
    line warning message, so is less likely to be ignored.

    Signed-off-by: David Daney
    To: linux-mips@linux-mips.org
    Patchwork: https://patchwork.linux-mips.org/patch/1905/
    Signed-off-by: Ralf Baechle

    David Daney
     
  • Octeon can use scratch registers in the TLB handlers. Octeon II can
    use LDX instructions.

    Signed-off-by: David Daney
    To: linux-mips@linux-mips.org
    Patchwork: https://patchwork.linux-mips.org/patch/1904/
    Signed-off-by: Ralf Baechle

    David Daney
     
  • Needed by Octeon II optimized TLB handlers.

    Signed-off-by: David Daney
    To: linux-mips@linux-mips.org
    Pachwork: https://patchwork.linux-mips.org/patch/1903/
    Signed-off-by: Ralf Baechle

    David Daney
     
  • If the CPU supports BBIT0 and BBIT1, use them in TLB handlers as they
    are more efficient than an AND followed by an branch and then
    restoring the clobbered register.

    Signed-off-by: David Daney
    To: linux-mips@linux-mips.org
    Patchwork: https://patchwork.linux-mips.org/patch/1873/
    Signed-off-by: Ralf Baechle

    David Daney
     
  • these are already defined, but declaring them allow them to be used
    outside of uasm.c.

    Signed-off-by: David Daney
    To: linux-mips@linux-mips.org
    Patchwork: https://patchwork.linux-mips.org/patch/1872/
    Signed-off-by: Ralf Baechle

    David Daney
     
  • Decide at runtime to use either Context or KScratch to hold the PGD
    pointer.

    Signed-off-by: David Daney
    To: linux-mips@linux-mips.org
    Patchwork: https://patchwork.linux-mips.org/patch/1876/
    Signed-off-by: Ralf Baechle

    David Daney
     
  • Signed-off-by: David Daney
    To: linux-mips@linux-mips.org
    Patchwork: https://patchwork.linux-mips.org/patch/1875/
    Signed-off-by: Ralf Baechle

    David Daney
     
  • Probe c0_config4 for KScratch registers and report them in /proc/cpuinfo.

    Signed-off-by: David Daney
    To: linux-mips@linux-mips.org
    Patchwork: https://patchwork.linux-mips.org/patch/1877/
    Signed-off-by: Ralf Baechle

    David Daney
     
  • This patch adds a generic solution to support multiple machines based on
    a given SoC within a single kernel image. It is implemented already for
    several other architectures but MIPS has no generic support for that yet.

    [Ralf: This competes with DT but DT is a much more complex solution and this
    code has been used by OpenWRT for a long time so for now DT is a bad reason
    to stop the merge but longer term this should be migrated to DT.]

    Signed-off-by: Gabor Juhos
    Cc: linux-mips@linux-mips.org
    Cc: kaloz@openwrt.org
    Cc: Luis R. Rodriguez
    Cc: Cliff Holden
    Patchwork: https://patchwork.linux-mips.org/patch/1814/
    Signed-off-by: Ralf Baechle

    Gabor Juhos