1. 15 6月, 2016 1 次提交
  2. 19 1月, 2016 1 次提交
  3. 31 7月, 2015 1 次提交
  4. 18 4月, 2015 1 次提交
  5. 30 8月, 2013 1 次提交
  6. 14 8月, 2013 1 次提交
    • C
      tile: fast-path unaligned memory access for tilegx · 2f9ac29e
      Chris Metcalf 提交于
      This change enables unaligned userspace memory access via a kernel
      fast path on tilegx.  The kernel tracks user PC/instruction pairs
      per-thread using a direct-mapped cache in userspace.  The cache
      maps those PC/instruction pairs to JIT'ed instruction sequences that
      load or store using byte-wide load store intructions and then
      synthesize 2-, 4- or 8-byte load or store results.  Once an
      instruction has been seen to generate an unaligned access once,
      subsequent hits on that instruction typically require overhead
      of only around 50 cycles if cache and TLB is hot.
      
      We support the prctl() PR_GET_UNALIGN / PR_SET_UNALIGN sys call to
      enable or disable unaligned fixups on a per-process basis.
      
      To do this we pull some of the tilepro unaligned support out of the
      single_step.c file; tilepro uses instruction disassembly for both
      single-step and unaligned access support.  Since tilegx actually has
      hardware singlestep support, though, it's cleaner to keep the tilegx
      unaligned access code in a separate file.  While we're at it,
      properly rename the tilepro-specific types, etc., to have tilepro
      suffixes instead of generic tile suffixes.
      Signed-off-by: NChris Metcalf <cmetcalf@tilera.com>
      2f9ac29e
  7. 25 4月, 2013 1 次提交
  8. 23 3月, 2013 1 次提交
  9. 22 3月, 2013 1 次提交
  10. 19 12月, 2012 2 次提交
  11. 15 12月, 2012 1 次提交
  12. 14 12月, 2012 1 次提交
  13. 02 11月, 2010 1 次提交
  14. 28 10月, 2010 2 次提交
  15. 16 10月, 2010 1 次提交
    • C
      arch/tile: make ptrace() work properly for TILE-Gx COMPAT mode · ce7f2a39
      Chris Metcalf 提交于
      Previously, we tried to pass 64-bit arguments through the
      "COMPAT" mode 32-bit syscall API, which turned out not to work
      well.  Now we just use straight 32-bit arguments in COMPAT mode,
      thus requiring individual registers to be read/written with
      two syscalls.  Of course this is uncommon, since usually all
      the registers are read or written at once.
      
      The restructuring applies to all the tile platforms, but is
      plausibly better than the original code in any case.
      Signed-off-by: NChris Metcalf <cmetcalf@tilera.com>
      ce7f2a39
  16. 07 7月, 2010 2 次提交
    • C
    • C
      arch/tile: Miscellaneous cleanup changes. · 0707ad30
      Chris Metcalf 提交于
      This commit is primarily changes caused by reviewing "sparse"
      and "checkpatch" output on our sources, so is somewhat noisy, since
      things like "printk() -> pr_err()" (or whatever) throughout the
      codebase tend to get tedious to read.  Rather than trying to tease
      apart precisely which things changed due to which type of code
      review, this commit includes various cleanups in the code:
      
      - sparse: Add declarations in headers for globals.
      - sparse: Fix __user annotations.
      - sparse: Using gfp_t consistently instead of int.
      - sparse: removing functions not actually used.
      - checkpatch: Clean up printk() warnings by using pr_info(), etc.;
        also avoid partial-line printks except in bootup code.
        - checkpatch: Use exposed structs rather than typedefs.
        - checkpatch: Change some C99 comments to C89 comments.
      
      In addition, a couple of minor other changes are rolled in
      to this commit:
      
      - Add support for a "raise" instruction to cause SIGFPE, etc., to be raised.
      - Remove some compat code that is unnecessary when we fully eliminate
        some of the deprecated syscalls from the generic syscall ABI.
      - Update the tile_defconfig to reflect current config contents.
      Signed-off-by: NChris Metcalf <cmetcalf@tilera.com>
      Acked-by: NArnd Bergmann <arnd@arndb.de>
      0707ad30
  17. 05 6月, 2010 1 次提交