1. 05 3月, 2013 1 次提交
    • M
      s390: critical section cleanup vs. machine checks · 6551fbdf
      Martin Schwidefsky 提交于
      The current machine check code uses the registers stored by the machine
      in the lowcore at __LC_GPREGS_SAVE_AREA as the registers of the interrupted
      context. The registers 0-7 of a user process can get clobbered if a machine
      checks interrupts the execution of a critical section in entry[64].S.
      
      The reason is that the critical section cleanup code may need to modify
      the PSW and the registers for the previous context to get to the end of a
      critical section. If registers 0-7 have to be replaced the relevant copy
      will be in the registers, which invalidates the copy in the lowcore. The
      machine check handler needs to explicitly store registers 0-7 to the stack.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
      6551fbdf
  2. 03 3月, 2013 39 次提交
    • J
      metag: Provide dma_get_sgtable() · c60ac315
      James Hogan 提交于
      metag/allmodconfig:
      
      drivers/media/v4l2-core/videobuf2-dma-contig.c: In function 'vb2_dc_get_base_sgt':
      drivers/media/v4l2-core/videobuf2-dma-contig.c:387: error: implicit declaration of function 'dma_get_sgtable'
      
      For architectures using dma_map_ops, dma_get_sgtable() is provided in
      <asm-generic/dma-mapping-common.h>.
      
      Metag does not use dma_map_ops yet, hence it should implement it as an
      inline stub using dma_common_get_sgtable().
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      Cc: Geert Uytterhoeven <geert@linux-m68k.org>
      Acked-by: NMarek Szyprowski <m.szyprowski@samsung.com>
      c60ac315
    • J
      metag: prom.h: remove declaration of metag_dt_memblock_reserve() · 2742c526
      James Hogan 提交于
      Metag doesn't have a metag_dt_memblock_reserve() function so remove the
      declaration from asm/prom.h.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      2742c526
    • J
      metag: copy devicetree to non-init memory · 2270e6d3
      James Hogan 提交于
      Make a copy of the device tree blob in non-init memory. It is required
      when using built-in device tree files that the platform code copies the
      blob to non-init memory prior to calling unflatten_device_tree(),
      otherwise the strings that the device tree refer to will get poisoned
      and potentially reused, breaking later reading of the device tree
      post-init (such as compatible matching in modules, debugfs, and the
      procfs interface).
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      Reviewed-by: NVineet Gupta <vgupta@synopsys.com>
      2270e6d3
    • J
      metag: cleanup metag_ksyms.c includes · d7900504
      James Hogan 提交于
      Minimise metag_ksyms.c includes to directly include the <asm/*.h> files
      that declare a particular symbol, and not include any unnecessary ones.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      d7900504
    • J
      metag: move mm/init.c exports out of metag_ksyms.c · 44c24510
      James Hogan 提交于
      It's less error prone to have function symbols exported immediately
      after the function rather than in metag_ksyms.c. Move each EXPORT_SYMBOL
      in metag_ksyms.c for symbols defined in mm/init.c into mm/init.c.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      44c24510
    • J
      metag: move usercopy.c exports out of metag_ksyms.c · 9da3ee9a
      James Hogan 提交于
      It's less error prone to have function symbols exported immediately
      after the function rather than in metag_ksyms.c. Move each EXPORT_SYMBOL
      in metag_ksyms.c for symbols defined in usercopy.c into usercopy.c
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      9da3ee9a
    • J
      metag: move setup.c exports out of metag_ksyms.c · 7293dbed
      James Hogan 提交于
      It's less error prone to have function symbols exported immediately
      after the function rather than in metag_ksyms.c. Move each EXPORT_SYMBOL
      in metag_ksyms.c for symbols defined in setup.c into setup.c
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      7293dbed
    • J
      metag: move kick.c exports out of metag_ksyms.c · aa29ec5f
      James Hogan 提交于
      It's less error prone to have function symbols exported immediately
      after the function rather than in metag_ksyms.c. Move each EXPORT_SYMBOL
      in metag_ksyms.c for symbols defined in kick.c into kick.c
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      aa29ec5f
    • J
      metag: move traps.c exports out of metag_ksyms.c · 9fb4aa87
      James Hogan 提交于
      It's less error prone to have function symbols exported immediately
      after the function rather than in metag_ksyms.c. Move each EXPORT_SYMBOL
      in metag_ksyms.c for symbols defined in traps.c into traps.c
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      9fb4aa87
    • J
      metag: move irq enable out of irqflags.h on SMP · fa771d02
      James Hogan 提交于
      The SMP version of arch_local_irq_enable() uses preempt_disable(), but
      <asm/irqflags.h> doesn't include <linux/preempt.h> causing the following
      errors on SMP when pstore/ftrace is enabled (caught by buildbot smp
      allyesconfig):
      
      In file included from include/linux/irqflags.h:15,
                       from fs/pstore/ftrace.c:16:
      arch/metag/include/asm/irqflags.h: In function 'arch_local_irq_enable':
      arch/metag/include/asm/irqflags.h:84: error: implicit declaration of function 'preempt_disable'
      arch/metag/include/asm/irqflags.h:86: error: implicit declaration of function 'preempt_enable_no_resched'
      
      However <linux/preempt.h> cannot be easily included from
      <asm/irqflags.h> as it can cause circular include dependencies in the
      !SMP case, and potentially in the SMP case in the future. Therefore move
      the SMP implementation of arch_local_irq_enable() into traps.c and use
      an inline version of get_trigger_mask() which is also defined in traps.c
      for SMP.
      
      This adds an extra layer of function call / stack push when
      preempt_disable needs to call other functions, however in the
      non-preemptive SMP case it should be about as fast, as it was already
      calling the get_trigger_mask() function which is now used inline.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      fa771d02
    • J
      metag: hugetlb: convert to vm_unmapped_area() · f75c28d8
      James Hogan 提交于
      Convert hugetlb_get_unmapped_area_new_pmd() to use vm_unmapped_area()
      rather than searching the virtual address space itself. This fixes the
      following errors in linux-next due to the specified members being
      removed after other architectures have already been converted:
      
      arch/metag/mm/hugetlbpage.c: In function 'hugetlb_get_unmapped_area_new_pmd':
      arch/metag/mm/hugetlbpage.c:199: error: 'struct mm_struct' has no member named 'cached_hole_size'
      arch/metag/mm/hugetlbpage.c:200: error: 'struct mm_struct' has no member named 'free_area_cache'
      arch/metag/mm/hugetlbpage.c:215: error: 'struct mm_struct' has no member named 'cached_hole_size'
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      Acked-by: NMichel Lespinasse <walken@google.com>
      f75c28d8
    • J
      metag: export clear_page and copy_page · c838e72a
      James Hogan 提交于
      Various file systems use clear_page() and copy_page(), so when they're
      built as modules we get build errors like the following:
      
      ERROR: "clear_page" [fs/ntfs/ntfs.ko] undefined!
      ERROR: "copy_page" [fs/nilfs2/nilfs2.ko] undefined!
      
      Therefore export these functions to modules from metag_ksyms.c to fix
      the errors. This was hit by a randconfig build.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      c838e72a
    • J
      metag: export metag_code_cache_flush_all · f626dc70
      James Hogan 提交于
      Various file systems indirectly use metag_code_cache_flush_all(), so
      when they're built as modules we get build errors like the following:
      
      ERROR: "metag_code_cache_flush_all" [fs/xfs/xfs.ko] undefined!
      
      Therefore export this function to modules to fix the errors. This was
      hit by a randconfig build.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      f626dc70
    • J
      metag: protect more non-MMU memory regions · 3d6b7bb0
      James Hogan 提交于
      Rename setup_txprivext() to setup_priv() and add initialisation of some
      more per-thread privilege protection registers:
      
       - TxPRIVSYSR: 0x04400000-0x047fffff
                     0x05000000-0x07ffffff
                     0x84000000-0x87ffffff
       - TxPIOREG:   0x02000000-0x02ffffff
                     0x04800000-0x048fffff
       - TxSYREG:    0x04000000-0x04000fff (except write fetch system event)
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      3d6b7bb0
    • J
      metag: make TXPRIVEXT bits explicit · c787c2d6
      James Hogan 提交于
      Define PRIV_BITS using explicit constants from <asm/metag_regs.h> rather
      than with a hard coded value. This also adds a couple of missing
      definitions for the TXPRIVEXT priv bits for protecting writes to TXTIMER
      and the trace registers.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      c787c2d6
    • J
      metag: kernel/setup.c: sort includes · 82f0167a
      James Hogan 提交于
      Sort includes in kernel/setup.c.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      82f0167a
    • J
      metag: add boot time LNKGET/LNKSET check · 883a6355
      James Hogan 提交于
      Add boot time check for whether LNKGET/LNKSET go through or around the
      cache. Depending on the configuration an info message (no harm), warning
      (technically wrong but no harm), or big WARN (expect failure in either
      kernel or userland) may be emitted if the behaviour is not as expected:
      
      Configuration                                Hardware   Response
      ------------------------------------------   --------   --------
      AROUND_CACHE                                 through    pr_info
      !AROUND_CACHE && ATOMICITY_LNKGET            around     WARN (kernel)
           "        && !ATOMICITY_LNKGET && SMP    around     WARN (user)
           "                   "         && !SMP   around     pr_warn
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      883a6355
    • J
      metag: add __init to metag_cache_probe() · 0a38a8ad
      James Hogan 提交于
      metag_cache_probe() is only called from setup_arch(), so add the __init
      attribute to it.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      0a38a8ad
    • J
      metag: Add JTAG Debug Adapter (DA) support · ae85ac71
      James Hogan 提交于
      Add basic JTAG Debug Adapter (DA) support so that drivers which
      communicate with the DA can detect whether one is actually present
      (otherwise the target will halt indefinitely).
      
      This allows the metag_da TTY driver and imgdafs filesystem driver to be
      built, updates defconfigs, and sets up the metag_da console early if
      it's configured in.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      ae85ac71
    • J
      metag: ftrace support · 00512bdd
      James Hogan 提交于
      Add ftrace support for metag.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      Cc: Frederic Weisbecker <fweisbec@gmail.com>
      Cc: Ingo Molnar <mingo@redhat.com>
      Reviewed-by: NSteven Rostedt <rostedt@goodmis.org>
      00512bdd
    • J
      metag: Perf · 903b20ad
      James Hogan 提交于
      Add Perf support for metag.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
      Cc: Paul Mackerras <paulus@samba.org>
      Cc: Ingo Molnar <mingo@redhat.com>
      Cc: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
      903b20ad
    • J
      metag: Build infrastructure · 5633004c
      James Hogan 提交于
      Add metag build infrastructure.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      5633004c
    • J
      metag: Various other headers · 1e57372e
      James Hogan 提交于
      Add the remaining metag header files:
       - byteorder.h, swab.h (byte order and swapping)
       - barrier.h, cpu.h. hwthread.h, processor.h (hardware thread related)
       - bug.h, elf.h, gpio.h, linkage.h, resource.h (other)
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      1e57372e
    • J
      metag: Stack unwinding · e8de3486
      James Hogan 提交于
      Add stack unwinding support for metag.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      e8de3486
    • J
      metag: Optimised library functions · 086e9dc0
      James Hogan 提交于
      Add optimised library functions for metag.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      086e9dc0
    • J
      metag: DMA · f507758c
      James Hogan 提交于
      Add DMA mapping code.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      f507758c
    • J
      metag: SMP support · 42682c6c
      James Hogan 提交于
      Add SMP support for metag. This allows Linux to take control of multiple
      hardware threads on a single Meta core, treating them as separate Linux
      CPUs.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      42682c6c
    • J
      metag: Atomics, locks and bitops · 6006c0d8
      James Hogan 提交于
      Add header files to implement Meta hardware thread locks (used by some
      other atomic operations), atomics, spinlocks, and bitops.
      
      There are 2 main types of atomic primitives for metag (in addition to
      IRQs off on UP):
       - LOCK instructions provide locking between hardware threads.
       - LNKGET/LNKSET instructions provide load-linked/store-conditional
         operations allowing for lighter weight atomics on Meta2
      
      LOCK instructions allow for hardware threads to acquire voluntary or
      exclusive hardware thread locks:
       - LOCK0 releases exclusive and voluntary lock from the running hardware
         thread.
       - LOCK1 acquires the voluntary hardware lock, blocking until it becomes
         available.
       - LOCK2 implies LOCK1, and additionally acquires the exclusive hardware
         lock, blocking all other hardware threads from executing.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      6006c0d8
    • J
      metag: Module support · 9b802d1f
      James Hogan 提交于
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      9b802d1f
    • J
      metag: Scheduling/Process management · 44dea393
      James Hogan 提交于
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      44dea393
    • J
      metag: System Calls · 26025bbf
      James Hogan 提交于
      Add metag system call and gateway page interfaces. The metag
      architecture port uses the generic system call numbers from
      asm-generic/unistd.h, as well as a user gateway page mapped at
      0x6ffff000 which contains fast atomic primitives (depending on SMP) and
      a fast method of accessing TLS data.
      
      System calls use the SWITCH instruction with the immediate 0x440001 to
      signal a system call.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      26025bbf
    • J
      metag: Internal and external irqchips · 5698c50d
      James Hogan 提交于
      Meta core internal interrupts (from HWSTATMETA and friends) are vectored
      onto the TR1 core trigger for the current thread. This is demultiplexed
      in irq-metag.c to individual Linux IRQs for each internal interrupt.
      
      External SoC interrupts (from HWSTATEXT and friends) are vectored onto
      the TR2 core trigger for the current thread. This is demultiplexed in
      irq-metag-ext.c to individual Linux IRQs for each external SoC interrupt.
      The external irqchip has devicetree bindings for configuring the number
      of irq banks and the type of masking available.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Grant Likely <grant.likely@secretlab.ca>
      Cc: Rob Herring <rob.herring@calxeda.com>
      Cc: Rob Landley <rob@landley.net>
      Cc: Dom Cobley <popcornmix@gmail.com>
      Cc: Simon Arlott <simon@fire.lp0.eu>
      Cc: Viresh Kumar <viresh.kumar@linaro.org>
      Cc: Maxime Ripard <maxime.ripard@free-electrons.com>
      Cc: devicetree-discuss@lists.ozlabs.org
      Cc: linux-doc@vger.kernel.org
      5698c50d
    • J
      metag: IRQ handling · 63047ea3
      James Hogan 提交于
      Add core IRQ handling for metag. The code in irq.c exposes the TBX
      signal numbers as Linux IRQs.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      63047ea3
    • J
      metag: Traps · ac919f08
      James Hogan 提交于
      Add trap code for metag. At the lowest level Meta traps (and return from
      interrupt instruction - RTI) simply swap the PC and PCX registers and
      optionally toggle the interrupt status bit (ISTAT). Low level TBX code
      in tbipcx.S handles the core context save, determine the TBX signal
      number based on the core trigger that fired (using the TXSTATI status
      register), and call TBX signal handlers (mostly in traps.c) via a vector
      table.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      Cc: Al Viro <viro@zeniv.linux.org.uk>
      ac919f08
    • J
      metag: Time keeping · a2c5d4ed
      James Hogan 提交于
      Add time keeping code for metag. Meta hardware threads have 2 timers.
      The background timer (TXTIMER) is used as a free-running time base, and
      the interrupt timer (TXTIMERI) is used for the timer interrupt. Both
      counters traditionally count at approximately 1MHz.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      Cc: John Stultz <johnstul@us.ibm.com>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      a2c5d4ed
    • J
      metag: ptrace · bc3966bf
      James Hogan 提交于
      The ptrace interface for metag provides access to some core register
      sets using the PTRACE_GETREGSET and PTRACE_SETREGSET operations. The
      details of the internal context structures is abstracted into user API
      structures to both ease use and allow flexibility to change the internal
      context layouts. Copyin and copyout functions for these register sets
      are exposed to allow signal handling code to use them to copy to and
      from the signal context.
      
      struct user_gp_regs (NT_PRSTATUS) provides access to the core general
      purpose register context.
      
      struct user_cb_regs (NT_METAG_CBUF) provides access to the TXCATCH*
      registers which contains information abuot a memory fault, unaligned
      access error or watchpoint. This can be modified to alter the way the
      fault is replayed on resume ("catch replay"), or to prevent the replay
      taking place.
      
      struct user_rp_state (NT_METAG_RPIPE) provides access to the state of
      the Meta read pipeline which can be used to hide memory latencies in
      hand optimised data loops.
      
      Extended DSP register state, DSP RAM, and hardware breakpoint registers
      aren't yet exposed through ptrace.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      Cc: Andrew Morton <akpm@linux-foundation.org>
      Cc: Denys Vlasenko <vda.linux@googlemail.com>
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Tony Lindgren <tony@atomide.com>
      Cc: "Paul E. McKenney" <paulmck@linux.vnet.ibm.com>
      bc3966bf
    • J
      metag: Device tree · 29dd78cf
      James Hogan 提交于
      Add device tree files to arch/metag.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      Reviewed-by: NVineet Gupta <vgupta@synopsys.com>
      29dd78cf
    • J
      metag: Signal handling · 262d96b0
      James Hogan 提交于
      Add signal handling code for metag.
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      Cc: Al Viro <viro@zeniv.linux.org.uk>
      262d96b0
    • J
      metag: TCM support · c438b58e
      James Hogan 提交于
      Add some TCM support
      Signed-off-by: NJames Hogan <james.hogan@imgtec.com>
      c438b58e