1. 22 9月, 2016 1 次提交
  2. 02 9月, 2016 1 次提交
    • J
      tty: xuartps: constify uart_ops structures · f098a0ae
      Julia Lawall 提交于
      Check for uart_ops structures that are only stored in the ops field of a
      uart_port structure.  This field is declared const, so uart_ops structures
      that have this property can be declared as const also.
      
      The semantic patch that makes this change is as follows:
      (http://coccinelle.lip6.fr/)
      
      // <smpl>
      @r disable optional_qualifier@
      identifier i;
      position p;
      @@
      static struct uart_ops i@p = { ... };
      
      @ok@
      identifier r.i;
      struct uart_port e;
      position p;
      @@
      e.ops = &i@p;
      
      @bad@
      position p != {r.p,ok.p};
      identifier r.i;
      struct uart_ops e;
      @@
      e@i@p
      
      @depends on !bad disable optional_qualifier@
      identifier r.i;
      @@
      static
      +const
       struct uart_ops i = { ... };
      // </smpl>
      Signed-off-by: NJulia Lawall <Julia.Lawall@lip6.fr>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      f098a0ae
  3. 26 6月, 2016 1 次提交
  4. 08 3月, 2016 1 次提交
  5. 07 2月, 2016 14 次提交
  6. 11 5月, 2015 1 次提交
  7. 28 4月, 2015 1 次提交
  8. 27 3月, 2015 6 次提交
  9. 07 3月, 2015 1 次提交
  10. 03 2月, 2015 1 次提交
    • N
      tty: xuartps: Fix RX hang, and TX corruption in termios call · 6ecde472
      Nathan Rossi 提交于
      The implementation of flushing the RX FIFO breaks in a number of cases,
      it is impossible to ensure an complete flush of the RX FIFO due to the
      hardware not allowing the use of the FIFOs when the receiver is disabled
      (Reading from the FIFO register does not remove it from the FIFO when
      the RX_EN=0 or RX_DIS=1). Additionally during an initial set_termios
      call where RX_DIS=1 causes a hang waiting forever for the RX FIFO to
      empty. On top of this the FIFO will be cleared by the use of the RXRST
      bits on the Control Register, making the RX flush pointless (as it does
      not preserve the data read anyway).
      
      Due to the TXRST the TX FIFO and transmitter can be interrupted during
      frame trasmission, causing corruption and additionally data lost in the
      FIFO. Most other serial drivers do not flush or clear the FIFOs during
      a termios configuration change and as such do not have issues with
      corruption. For this UART controller is it required that the TXRST/RXRST
      bit be flagged during the change, this means that the data in the FIFO
      will be dropped when changing configuration. In order to prevent data
      loss and corruption of the transmitted data, wait until the TX FIFO is
      empty before changing the configuration. The performance of this may
      cause the set_termios call to take a longer amount of time especially
      on lower baud rates, however it is comparable to the same performance
      hit that a console_write call costs.
      Signed-off-by: NNathan Rossi <nathan.rossi@xilinx.com>
      Acked-by: NAnirudha Sarangi <anirudh@xilinx.com>
      Acked-by: NHarini Katakam <harinik@xilinx.com>
      Signed-off-by: NMichal Simek <michal.simek@xilinx.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      6ecde472
  11. 07 11月, 2014 1 次提交
  12. 29 9月, 2014 1 次提交
  13. 09 9月, 2014 2 次提交
  14. 10 7月, 2014 1 次提交
  15. 25 4月, 2014 7 次提交