1. 05 3月, 2014 1 次提交
  2. 16 1月, 2013 5 次提交
  3. 12 12月, 2012 6 次提交
    • M
      MN10300: fix debug polling in ttySM driver · 0369c360
      Mark Salter 提交于
      The debug polling interface for the SoC serial ports did not work in the case
      where the serial ports were not also used as a console. In that case, the
      uart driver startup function will not be called so tx and rx would not be
      enabled in the hardware control register. Also, vdma interrupts would not be
      enabled which the poll_get_char function relied on. This patch makes sure that
      the rx and tx enables are set as a consequence of the uart set_termios call
      which is the only initialization done for the debug polling interface. Also,
      the poll_get_char now handles the case where vdma interrupts are not enabled.
      Signed-off-by: NMark Salter <msalter@redhat.com>
      Signed-off-by: NDavid Howells <dhowells@redhat.com>
      0369c360
    • M
      MN10300: ttySM: clean up unnecessary casting · 97a70b14
      Mark Salter 提交于
      The ttySM uart data register pointers are declared as void* pointers. Change
      them to u8* pointers so we don't need to use casts in the code.
      Signed-off-by: NMark Salter <msalter@redhat.com>
      Signed-off-by: NDavid Howells <dhowells@redhat.com>
      97a70b14
    • M
      MN10300: fix SMP synchronization between txdma and serial driver · 8f0bcbca
      Mark Salter 提交于
      The SoC serial port driver uses a high priority interrupt to handle tx of
      characters in the tx ring buffer. The driver needs to disable/enable this IRQ
      from outside of irq context. The original code to do this is not foolproof on
      SMP machines because the IRQ running on one core could still access the serial
      port for a short time after the driver running on another core disables the
      interrupt. This patch adds a flag to tell the IRQ handler that the driver
      wants to disable the interrupt. After seeing the flag, the IRQ handler will
      immediately disable the interrupt and exit. After setting the flag, the driver
      will wait for interrupt to be disabled by the IRQ handler.
      Signed-off-by: NMark Salter <msalter@redhat.com>
      Signed-off-by: NDavid Howells <dhowells@redhat.com>
      8f0bcbca
    • M
      MN10300: fix serial port vdma irq setup for SMP · 8d160027
      Mark Salter 提交于
      The builtin SoC serial ports have no FIFOs and use a virtual DMA mechanism
      based on high priority IRQs to avoid overruns. These high priority interrupts
      are pinned to cpu#0 on SMP systems. This patch fixes a problem with SMP where
      the set_intr_level() interface is used to set the priority for these IRQs. The
      set_intr_level() function sets priority on the local cpu but on SMP systems,
      this code may be run on some other cpu than the one handling the interrupts.
      Instead of setting interrupt level explicitly, this patch uses a special
      irq_chip for these interrupts so that the mask/unmask methods can set the
      interrupt level implicitly.
      Signed-off-by: NMark Salter <msalter@redhat.com>
      Signed-off-by: NDavid Howells <dhowells@redhat.com>
      8d160027
    • M
      MN10300: cleanup IRQ affinity setting · 7d361cb7
      Mark Salter 提交于
      The irq_set_affinity handler for the mn10300 cpu pic had some hard-coded IRQs
      which were not to be migrated from one cpu to another. This patch cleans those
      up by using a combination of IRQF_NOBALANCING and specialized irq chips with
      no irq_set_affinity handler. This maintains the previous behavior by using
      generic IRQ interfaces rather than hard coding IRQ numbers in the default
      irq_set_affinity handler.
      Signed-off-by: NMark Salter <msalter@redhat.com>
      Signed-off-by: NDavid Howells <dhowells@redhat.com>
      7d361cb7
    • D
      MN10300: ttySM: Use memory barriers correctly in circular buffer logic · c98c406e
      David Howells 提交于
      Use memory barriers correctly in the circular buffer logic used in the driver,
      as documented in Documentation/circular-buffers.txt.
      Signed-off-by: NDavid Howells <dhowells@redhat.com>
      Signed-off-by: NMark Salter <msalter@redhat.com>
      c98c406e
  4. 29 3月, 2012 1 次提交
  5. 29 3月, 2011 1 次提交
  6. 19 3月, 2011 3 次提交
  7. 28 10月, 2010 1 次提交
  8. 15 9月, 2010 1 次提交
  9. 13 8月, 2010 1 次提交
  10. 12 1月, 2010 1 次提交
  11. 24 9月, 2009 1 次提交
  12. 10 4月, 2009 1 次提交
  13. 11 12月, 2008 1 次提交
    • A
      MN10300: Discard low-priority Tx interrupts when closing an on-chip serial port · a8893fb3
      Akira Takeuchi 提交于
      Discard low-prioriy Tx interrupts when closing an MN10300 on-chip serial port.
      
      The MN10300 on-chip serial port uses three interrupts to manage its serial
      ports:
      
       (1) A very high priority interrupt that drives virtual DMA for Rx.
      
       (2) A very high priority interrupt that drives virtual DMA for Tx.
      
       (3) A normal priority virtual interrupt that does the normal UART interrupt
           stuff and is shared between Rx and Tx.
      
      mn10300_serial_stop_tx() only disables the high priority Tx interrupt.  It
      doesn't also disable the normal priority one because it is shared with Rx.
      
      However, the high priority interrupt may interrupt local_irq_disabled()
      sections, and so may have queued up a low priority virtual interrupt whilst the
      UART driver is asking for the Tx interrupt to be disabled.
      
      The result of this can be an oops when we try to process the interrupt in
      mn10300_serial_transmit_interrupt() as port->uart.info and port->uart.info->tty
      may have gone away.
      
      To deal with this, if either of those pointers is NULL, we make sure the
      high-priority Tx interrupt is disabled and discard the interrupt.  The low
      priority interrupt is disabled by the mn10300_serial_pic irq_chip table.
      Signed-off-by: NAkira Takeuchi <takeuchi.akr@jp.panasonic.com>
      Signed-off-by: NDavid Howells <dhowells@redhat.com>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      a8893fb3
  14. 24 8月, 2008 1 次提交
  15. 21 7月, 2008 1 次提交
  16. 09 2月, 2008 1 次提交