1. 11 3月, 2016 1 次提交
    • M
      xtensa: use context structure for debug exceptions · 6ec7026a
      Max Filippov 提交于
      With implementation of data breakpoints debug exceptions raised when
      PS.EXCM is set need to be handled, e.g. window overflow code can write
      to watched userspace address. Currently debug exception handler uses
      EXCSAVE and DEPC SRs to save temporary registers, but DEPC may not be
      available when PS.EXCM is set and more space will be needed to save
      additional state.
      Reorganize debug context: create per-CPU structure debug_table instance
      and store its address in the EXCSAVE<debug level> instead of
      debug_exception function address. Expand this structure when more save
      space is needed.
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      6ec7026a
  2. 02 11月, 2015 1 次提交
    • M
      xtensa: fixes for configs without loop option · 5029615e
      Max Filippov 提交于
      Build-time fixes:
      - make lbeg/lend/lcount save/restore conditional on kernel entry;
      - don't clear lcount in platform_restart functions unconditionally.
      
      Run-time fixes:
      - use correct end of range register in __endla paired with __loopt, not
        the unused temporary register. This fixes .bss zero-initialization.
        Update comments in asmmacro.h;
      - don't clobber a10 in the usercopy that leads to access to unmapped
        memory.
      
      Cc: <stable@vger.kernel.org>
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      5029615e
  3. 17 8月, 2015 5 次提交
    • M
      xtensa: implement fake NMI · 38fef73c
      Max Filippov 提交于
      In case perf IRQ is the highest of the medium-level IRQs, and is alone
      on its level, it may be treated as NMI:
      - LOCKLEVEL is defined to be one level less than EXCM level,
      - IRQ masking never lowers current IRQ level,
      - new fake exception cause code, EXCCAUSE_MAPPED_NMI is assigned to that
        IRQ; new second level exception handler, do_nmi, assigned to it
        handles it as NMI,
      - atomic operations in configurations without s32c1i still need to mask
        all interrupts.
      
      Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
      Acked-by: NPeter Zijlstra (Intel) <peterz@infradead.org>
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      38fef73c
    • M
      xtensa: don't touch EXC_TABLE_FIXUP in _switch_to · 98e29832
      Max Filippov 提交于
      There's no way _switch_to can produce double exceptions now, don't
      enter/leave EXC_TABLE_FIXUP critical section.
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      98e29832
    • M
      xtensa: fix kernel register spilling · 77d6273e
      Max Filippov 提交于
      call12 can't be safely used as the first call in the inline function,
      because the compiler does not extend the stack frame of the bounding
      function accordingly, which may result in corruption of local variables.
      
      If a call needs to be done, do call8 first followed by call12.
      
      For pure assembly code in _switch_to increase stack frame size of the
      bounding function.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      77d6273e
    • M
      xtensa: reorganize irq flags tracing · 7d5f6a9a
      Max Filippov 提交于
      entry.s only disables IRQs on hardware IRQ, move trace_hardirqs_off call
      into do_interrupt. Check actual intlevel that will be restored on return
      from exception handler to decide if trace_hardirqs_on should be called.
      Annotate IRQ on/off points in the TIF_* handling loop on return from
      exception handler.
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      7d5f6a9a
    • M
      xtensa: keep exception/interrupt stack continuous · b6569439
      Max Filippov 提交于
      Restore original a0 in the kernel exception stack frame. This way it
      looks like the frame that got interrupt/exception did alloca (copy a0 and
      a1 spilled under old stack to the new location as well) to save registers
      and then did a call to handler.
      The point where interrupt/exception was taken is not in the stack chain,
      only in pt_regs (call4 from that address can be simulated to keep it in
      the stack trace).
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      b6569439
  4. 15 7月, 2015 1 次提交
  5. 14 8月, 2014 4 次提交
    • M
      xtensa: deprecate fast_xtensa and fast_spill_registers syscalls · 9184289c
      Max Filippov 提交于
      These syscalls are not used by userspace tools for some time now, and
      they have issues when called with invalid arguments. It's not worth
      changing signal delivery mechanism as we don't expect any new users for
      these syscalls. Let's keep them for backwards compatibility under #ifdef,
      disabled by default.
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      9184289c
    • M
      xtensa: fix a6 and a7 handling in fast_syscall_xtensa · d1b6ba82
      Max Filippov 提交于
      Remove restoring a6 on some return paths and instead modify and restore
      it in a single place, using symbolic name.
      Correctly restore a7 from PT_AREG7 in case of illegal a6 value.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      d1b6ba82
    • M
      xtensa: fix TLBTEMP_BASE_2 region handling in fast_second_level_miss · 7128039f
      Max Filippov 提交于
      Current definition of TLBTEMP_BASE_2 is always 32K above the
      TLBTEMP_BASE_1, whereas fast_second_level_miss handler for the TLBTEMP
      region analyzes virtual address bit (PAGE_SHIFT + DCACHE_ALIAS_ORDER)
      to determine TLBTEMP region where the fault happened. The size of the
      TLBTEMP region is also checked incorrectly: not 64K, but twice data
      cache way size (whicht may as well be less than the instruction cache
      way size).
      
      Fix TLBTEMP_BASE_2 to be TLBTEMP_BASE_1 + data cache way size.
      Provide TLBTEMP_SIZE that is a greater of doubled data cache way size or
      the instruction cache way size, and use it to determine if the second
      level TLB miss occured in the TLBTEMP region.
      
      Practical occurence of page faults in the TLBTEMP area is extremely
      rare, this code can be tested by deletion of all w[di]tlb instructions
      in the tlbtemp_mapping region.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      7128039f
    • M
      xtensa: fix access to THREAD_RA/THREAD_SP/THREAD_DS · 52247123
      Max Filippov 提交于
      With SMP and a lot of debug options enabled task_struct::thread gets out
      of reach of s32i/l32i instructions with base pointing at task_struct,
      breaking build with the following messages:
      
        arch/xtensa/kernel/entry.S: Assembler messages:
        arch/xtensa/kernel/entry.S:1002: Error: operand 3 of 'l32i.n' has invalid value '1048'
        arch/xtensa/kernel/entry.S:1831: Error: operand 3 of 's32i.n' has invalid value '1040'
        arch/xtensa/kernel/entry.S:1832: Error: operand 3 of 's32i.n' has invalid value '1044'
      
      Change base to point to task_struct::thread in such cases.
      Don't use a10 in _switch_to to save/restore prev pointer as a2 is not
      clobbered.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
      52247123
  6. 29 1月, 2014 1 次提交
    • C
      xtensa: fix fast_syscall_spill_registers · 6b5a1f74
      Chris Zankel 提交于
      The original implementation could clobber registers under certain conditions.
      
      The Xtensa processor architecture uses windowed registers and the original
      implementation was using a4 as a temporary register, which under certain
      conditions could be register a0 of the oldest window frame, and didn't always
      restore the content correctly.
      
      By moving the _spill_registers routine inside the fast system call, it frees
      up one more register (the return address is not required anymore) for the
      spill routine.
      Signed-off-by: NChris Zankel <chris@zankel.net>
      6b5a1f74
  7. 26 1月, 2014 2 次提交
  8. 16 10月, 2013 1 次提交
  9. 07 9月, 2013 4 次提交
  10. 08 7月, 2013 1 次提交
  11. 21 5月, 2013 1 次提交
  12. 09 5月, 2013 2 次提交
  13. 24 2月, 2013 3 次提交
  14. 19 12月, 2012 3 次提交
  15. 26 10月, 2012 2 次提交
  16. 20 10月, 2012 1 次提交
  17. 16 10月, 2012 1 次提交
  18. 22 5月, 2012 2 次提交
  19. 31 3月, 2011 1 次提交
  20. 02 5月, 2010 1 次提交
  21. 09 2月, 2010 1 次提交
  22. 03 4月, 2009 1 次提交