1. 02 3月, 2011 7 次提交
    • C
      arch/tile: avoid a simulator warning during bootup · 401586e9
      Chris Metcalf 提交于
      As the added comment says, we can sometimes see a coherence warning
      from our simulator if the "swapper_pgprot" variable on the boot cpu
      has not been evicted from cache by the time the other cpus come up.
      Force it to be evicted so we never see the warning.
      Signed-off-by: NChris Metcalf <cmetcalf@tilera.com>
      401586e9
    • C
      arch/tile: export <asm/hardwall.h> to userspace · 9ff27fdb
      Chris Metcalf 提交于
      This should have been as part of the initial hardwall submission to
      LKML but was overlooked.  The header provides the ioctl definitions for
      manipulating the hardwall fd, so needs to be available to userspace.
      Signed-off-by: NChris Metcalf <cmetcalf@tilera.com>
      9ff27fdb
    • C
      arch/tile: warn and retry if an IPI is not accepted by the target cpu · bbeee4b2
      Chris Metcalf 提交于
      Previously we assumed this was impossible, but in fact it can happen.
      Handle it gracefully by retrying after issuing a warning.
      Signed-off-by: NChris Metcalf <cmetcalf@tilera.com>
      bbeee4b2
    • C
      arch/tile: stop disabling INTCTRL_1 interrupts during hypervisor downcalls · b2ce2bda
      Chris Metcalf 提交于
      The problem was that this could lead to IPIs being disabled during
      the softirq processing after a hypervisor downcall (e.g. for I/O),
      since both IPI and device interrupts use the INCTRL_1 downcall mechanism.
      When this happened at the wrong time, it could lead to deadlock.
      
      Luckily, we were already maintaining the per-interrupt state we need,
      and using it in the proper way in the hypervisor, so all we had to do
      was to change Linux to stop blocking downcall interrupts for the entire
      length of the downcall.  (Now they're blocked while we're executing the
      downcall routine itself, but not while we're executing any subsequent
      softirq routines.)  The hypervisor is doing a very small amount of
      work it no longer needs to do (masking INTCTRL_1 on entry to the client
      interrupt routine), but doing so means that older versions of Tile Linux
      will continue to work with a current hypervisor, so that seems reasonable.
      Signed-off-by: NChris Metcalf <cmetcalf@tilera.com>
      b2ce2bda
    • C
      arch/tile: fix __ndelay etc to work better · 13371731
      Chris Metcalf 提交于
      The current implementations of __ndelay and __udelay call a hypervisor
      service to delay, but the hypervisor service isn't actually implemented
      very well, and the consensus is that Linux should handle figuring this
      out natively and not use a hypervisor service.
      
      By converting nanoseconds to cycles, and then spinning until the
      cycle counter reaches the desired cycle, we get several benefits:
      first, we are sensitive to the actual clock speed; second, we use
      less power by issuing a slow SPR read once every six cycles while
      we delay; and third, we properly handle the case of an interrupt by
      exiting at the target time rather than after some number of cycles.
      Signed-off-by: NChris Metcalf <cmetcalf@tilera.com>
      13371731
    • C
      arch/tile: bug fix: exec'ed task thought it was still single-stepping · 04f7a3f1
      Chris Metcalf 提交于
      To handle single-step, tile mmap's a page of memory in the process
      space for each thread and uses it to construct a version of the
      instruction that we want to single step.  If the process exec's,
      though, we lose that mapping, and the kernel needs to be aware that
      it will need to recreate it if the exec'ed process than tries to
      single-step as well.
      
      Also correct some int32_t to s32 for better kernel style.
      Signed-off-by: NChris Metcalf <cmetcalf@tilera.com>
      04f7a3f1
    • C
      arch/tile: catch up with section naming convention in 2.6.35 · 2cb82400
      Chris Metcalf 提交于
      The convention changed to, e.g., ".data..page_aligned".  This commit
      fixes the places in the tile architecture that were still using the
      old convention.  One tile-specific section (.init.page) was dropped
      in favor of just using an "aligned" attribute.
      
      Sam Ravnborg <sam@ravnborg.org> pointed out __PAGE_ALIGNED_BSS, etc.
      Signed-off-by: NChris Metcalf <cmetcalf@tilera.com>
      2cb82400
  2. 25 2月, 2011 1 次提交
  3. 24 2月, 2011 5 次提交
  4. 22 2月, 2011 27 次提交