1. 24 7月, 2015 2 次提交
    • P
      tty: vt: Fix !TASK_RUNNING diagnostic warning from paste_selection() · 61e86cc9
      Peter Hurley 提交于
      Pasting text with gpm on a VC produced warning [1]. Reset task state
      to TASK_RUNNING in the paste_selection() loop, if the loop did not
      sleep.
      
      [1]
      WARNING: CPU: 6 PID: 1960 at /home/peter/src/kernels/mainline/kernel/sched/core.c:7286 __might_sleep+0x7f/0x90()
      do not call blocking ops when !TASK_RUNNING; state=1 set at [<ffffffff8151805e>] paste_selection+0x9e/0x1a0
      Modules linked in: btrfs xor raid6_pq ufs qnx4 hfsplus hfs minix ntfs msdos jfs xfs libcrc32c .....
      CPU: 6 PID: 1960 Comm: gpm Not tainted 4.1.0-rc7+tty-xeon+debug #rc7+tty
      Hardware name: Dell Inc. Precision WorkStation T5400  /0RW203, BIOS A11 04/30/2012
       ffffffff81c9c0a0 ffff8802b0fd3ac8 ffffffff8185778a 0000000000000001
       ffff8802b0fd3b18 ffff8802b0fd3b08 ffffffff8108039a ffffffff82ae8510
       ffffffff81c9ce00 0000000000000015 0000000000000000 0000000000000000
      Call Trace:
       [<ffffffff8185778a>] dump_stack+0x4f/0x7b
       [<ffffffff8108039a>] warn_slowpath_common+0x8a/0xc0
       [<ffffffff81080416>] warn_slowpath_fmt+0x46/0x50
       [<ffffffff810ddced>] ? __lock_acquire+0xe2d/0x13a0
       [<ffffffff8151805e>] ? paste_selection+0x9e/0x1a0
       [<ffffffff8151805e>] ? paste_selection+0x9e/0x1a0
       [<ffffffff810ad4ff>] __might_sleep+0x7f/0x90
       [<ffffffff8185f76a>] down_read+0x2a/0xa0
       [<ffffffff810bb1d8>] ? sched_clock_cpu+0xb8/0xe0
       [<ffffffff8150d1dc>] n_tty_receive_buf_common+0x4c/0xba0
       [<ffffffff810dc875>] ? mark_held_locks+0x75/0xa0
       [<ffffffff81861c95>] ? _raw_spin_unlock_irqrestore+0x65/0x80
       [<ffffffff810b49a1>] ? get_parent_ip+0x11/0x50
       [<ffffffff8150dd44>] n_tty_receive_buf2+0x14/0x20
       [<ffffffff81518117>] paste_selection+0x157/0x1a0
       [<ffffffff810b77b0>] ? wake_up_state+0x20/0x20
       [<ffffffff815203f8>] tioclinux+0xb8/0x2c0
       [<ffffffff81515bfe>] vt_ioctl+0xaee/0x11a0
       [<ffffffff810baf75>] ? sched_clock_local+0x25/0x90
       [<ffffffff810bbe11>] ? vtime_account_user+0x91/0xa0
       [<ffffffff8150810c>] tty_ioctl+0x20c/0xe20
       [<ffffffff810bbe11>] ? vtime_account_user+0x91/0xa0
       [<ffffffff810b49a1>] ? get_parent_ip+0x11/0x50
       [<ffffffff810b4a69>] ? preempt_count_sub+0x49/0x50
       [<ffffffff811ab71c>] ? context_tracking_exit+0x5c/0x290
       [<ffffffff811ab71c>] ? context_tracking_exit+0x5c/0x290
       [<ffffffff81248b98>] do_vfs_ioctl+0x318/0x570
       [<ffffffff810dca8d>] ? trace_hardirqs_on+0xd/0x10
       [<ffffffff810dc9b5>] ? trace_hardirqs_on_caller+0x115/0x1e0
       [<ffffffff81254acc>] ? __fget_light+0x6c/0xa0
       [<ffffffff81248e71>] SyS_ioctl+0x81/0xa0
       [<ffffffff81862832>] system_call_fastpath+0x16/0x7a
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      61e86cc9
    • D
      tty/vt: Fix the memory leak in visual_init · 08b33249
      Dongxing Zhang 提交于
      If vc->vc_uni_pagedir_loc is not NULL, its refcount needs to be
      decreased before vc_uni_pagedir_loc is re-assigned.
      
      unreferenced object 0xffff88002cdd13b0 (size 512):
        comm "setfont", pid 503, jiffies 4294896503 (age 722.828s)
        hex dump (first 32 bytes):
          40 92 61 2b 00 88 ff ff 00 00 00 00 00 00 00 00  @.a+............
          00 00 00 00 00 00 00 00 a0 ad 61 2b 00 88 ff ff  ..........a+....
        backtrace:
          [<ffffffff817b755e>] kmemleak_alloc+0x4e/0xb0
          [<ffffffff811d4898>] kmem_cache_alloc_trace+0x1c8/0x240
          [<ffffffff814ae7d3>] con_do_clear_unimap.isra.2+0x83/0xe0
          [<ffffffff814ae9b2>] con_clear_unimap+0x22/0x40
          [<ffffffff814a8db8>] vt_ioctl+0xeb8/0x1170
          [<ffffffff8149b458>] tty_ioctl+0x208/0xca0
          [<ffffffff81207858>] do_vfs_ioctl+0x2f8/0x510
          [<ffffffff81207af1>] SyS_ioctl+0x81/0xa0
          [<ffffffff817ca2b2>] system_call_fastpath+0x16/0x75
          [<ffffffffffffffff>] 0xffffffffffffffff
      unreferenced object 0xffff88002b619240 (size 256):
        comm "setfont", pid 503, jiffies 4294896503 (age 722.828s)
        hex dump (first 32 bytes):
          90 bc 84 d5 00 88 ff ff 58 85 84 d5 00 88 ff ff  ........X.......
          88 ac 84 d5 00 88 ff ff e0 b1 84 d5 00 88 ff ff  ................
        backtrace:
          [<ffffffff817b755e>] kmemleak_alloc+0x4e/0xb0
          [<ffffffff811d4898>] kmem_cache_alloc_trace+0x1c8/0x240
          [<ffffffff814ae286>] con_insert_unipair+0x86/0x170
          [<ffffffff814af107>] con_set_unimap+0x1b7/0x280
          [<ffffffff814a8d65>] vt_ioctl+0xe65/0x1170
          [<ffffffff8149b458>] tty_ioctl+0x208/0xca0
          [<ffffffff81207858>] do_vfs_ioctl+0x2f8/0x510
          [<ffffffff81207af1>] SyS_ioctl+0x81/0xa0
          [<ffffffff817ca2b2>] system_call_fastpath+0x16/0x75
          [<ffffffffffffffff>] 0xffffffffffffffff
      Signed-off-by: NDongxing Zhang <dongxing.zhang@intel.com>
      Signed-off-by: NXiaoming Wang <xiaoming.wang@intel.com>
      Reviewed-by: NPeter Hurley <peter@hurleysoftware.com>
      Tested-by: NKonstantin Khlebnikov <khlebnikov@yandex-team.ru>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      08b33249
  2. 17 6月, 2015 2 次提交
  3. 11 5月, 2015 4 次提交
    • D
      vt: Don't check KD_GRAPHICS when binding/unbinding · 77232f79
      Daniel Vetter 提交于
      This was introduced in
      
      commit 6db4063c
      Author: Antonino A. Daplas <adaplas@gmail.com>
      Date:   Mon Jun 26 00:27:12 2006 -0700
      
          [PATCH] VT binding: Add sysfs control to the VT layer
      
      with the justification
      
          "In addition, if any of the consoles are in KD_GRAPHICS mode, binding and
          unbinding will not succeed.  KD_GRAPHICS mode usually indicates that the
          underlying console hardware is used for other purposes other than displaying
          text (ie X).  This feature should prevent binding/unbinding from interfering
          with a graphics application using the VT."
      
      I think we should lift this artificial restriction though:
      - KD_GRAPHICS doesn't get cleaned up automatically, which means it's
        easy to have terminals stuck in KD_GRAPHICS when hacking around on
        X.
      - X doesn't really care, especially with drm where kms already blocks
        fbdev (and hence fbcon) when there's an active compositor.
      - This is a root-only interface with a separate .config option and
        it's possible to hang your machine already anyway if you
        unload/reload drivers and don't know what you're doing.
      
      With this patch i915.ko module reloading works again reliably,
      something in the recent fedora upgrades broke things.
      
      Cc: Antonino A. Daplas <adaplas@gmail.com>
      Cc: Peter Hurley <peter@hurleysoftware.com>
      Cc: Imre Deak <imre.deak@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@intel.com>
      Acked-by: NDavid Herrmann <dh.herrmann@gmail.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      77232f79
    • I
      vt: fix console lock vs. kernfs s_active lock order · d364b5c3
      Imre Deak 提交于
      Currently there is a lock order problem between the console lock and the
      kernfs s_active lock of the console driver's bind sysfs entry. When
      writing to the sysfs entry the lock order is first s_active then console
      lock, when unregistering the console driver via
      do_unregister_con_driver() the order is the opposite. See the below
      bugzilla reference for one instance of a lockdep backtrace.
      
      Fix this by unregistering the console driver from a deferred work, where
      we can safely drop the console lock while unregistering the device and
      corresponding sysfs entries (which in turn acquire s_active). Note that
      we have to keep the console driver slot in the registered_con_driver
      array reserved for the driver that's being unregistered until it's fully
      removed. Otherwise a concurrent call to do_register_con_driver could
      try to reuse the same slot and fail when registering the corresponding
      device with a minor index that's still in use.
      
      Note that the referenced bug report contains two dmesg logs with two
      distinct lockdep reports: [1] is about a locking scenario involving
      s_active, console_lock and the fb_notifier list lock, while [2] is
      about a locking scenario involving only s_active and console_lock.
      In [1] locking fb_notifier triggers the lockdep warning only because
      of its dependence on console_lock, otherwise case [1] is the same
      s_active<->console_lock dependency problem fixed by this patch.
      Before this change we have the following locking scenarios involving
      the 3 locks:
      
      a) via do_unregister_framebuffer()->...->do_unregister_con_driver():
         1. console lock 2. fb_notifier lock 3. s_active lock
      b) for example via give_up_console()->do_unregister_con_driver():
         1. console lock 2. s_active lock
      c) via vt_bind()/vt_unbind():
         1. s_active lock 2. console lock
      
      Since c) is the console bind sysfs entry's write code path we can't
      change the locking order there. We can only fix this issue by removing
      s_active's dependence on the other two locks in a) and b). We can do
      this only in the vt code which owns the corresponding sysfs entry, so
      that after the change we have:
      
      a) 1. console lock 2. fb_notifier lock
      b) 1. console lock
      c) 1. s_active lock 2. console lock
      d) in the new con_driver_unregister_callback():
         1. s_active lock
      
      [1] https://bugs.freedesktop.org/attachment.cgi?id=87716
      [2] https://bugs.freedesktop.org/attachment.cgi?id=107602
      
      v2:
      - get console_lock earlier in con_driver_unregister_callback(), so we
        protect the following console driver field assignments there
      - add code coment explaining the reason for deferring the sysfs entry
        removal
      - add a third paragraph to the commit message explaining why there are
        two distinct lockdep reports and that this issue is independent of
        fb/fbcon. (Peter Hurley)
      v3:
      - clarify further the third paragraph
      v4:
      - rebased on v4 of patch 1/3
      Signed-off-by: NImre Deak <imre.deak@intel.com>
      Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      d364b5c3
    • S
      vt: add cursor blink interval escape sequence · bd63364c
      Scot Doyle 提交于
      Add an escape sequence to specify the current console's cursor blink
      interval. The interval is specified as a number of milliseconds until
      the next cursor display state toggle, from 50 to 65535. /proc/loadavg
      did not show a difference with a one msec interval, but the lower
      bound is set to 50 msecs since slower hardware wasn't tested.
      
      Store the interval in the vc_data structure for later access by fbcon,
      initializing the value to fbcon's current hardcoded value of 200 msecs.
      Signed-off-by: NScot Doyle <lkml14@scotdoyle.com>
      Acked-by: NPavel Machek <pavel@ucw.cz>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      bd63364c
    • G
      tty: consolemap.c: move assignment out of if () block · 6d4e751e
      Greg Kroah-Hartman 提交于
      We should not be doing assignments within an if () block
      so fix up the code to not do this.
      
      change was created using Coccinelle.
      
      CC: Jiri Slaby <jslaby@suse.cz>
      CC: Takashi Iwai <tiwai@suse.de>
      CC: Imre Deak <imre.deak@intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      6d4e751e
  4. 26 3月, 2015 1 次提交
  5. 07 3月, 2015 3 次提交
  6. 03 2月, 2015 1 次提交
  7. 10 1月, 2015 2 次提交
    • I
      vt: fix locking around vt_bind/vt_unbind · 4c215fe8
      Imre Deak 提交于
      Currently vt_bind and vt_unbind access at least the con_driver object
      and registered_con_driver array without holding the console lock. Fix
      this by locking around the whole function in each case.
      Signed-off-by: NImre Deak <imre.deak@intel.com>
      Reviewed-by: NPeter Hurley <peter@hurleysoftware.com>
      Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      4c215fe8
    • I
      vt: fix check for system/busy console drivers when unregistering them · 2cf30f75
      Imre Deak 提交于
      The default console driver (conswitchp) and busy drivers bound to a
      console (as reported by con_is_bound()) shouldn't be unregistered.
      System console drivers (without the CON_DRIVER_FLAG_MODULE flag) can be
      unregistered, provided they are neither default nor busy. The current
      code checks for the CON_DRIVER_FLAG_INIT flag but this doesn't make
      sense: this flag is set for a driver whenever its associated console's
      con_startup() function is called, which first happens when the console
      driver is registered (so before the console gets bound) and gets cleared
      when the console gets unbound. The purpose of this flag is to show if we
      need to call con_startup() on a console before we use it.
      
      Based on the above, do_unregister_con_driver() in its current form will
      allow unregistering a console driver only if it was never bound, but
      will refuse to unregister one that was bound and later unbound.
      
      Fix this by dropping the CON_DRIVER_FLAG_INIT check, allowing
      unregistering of any console driver provided that it's not the default
      one and it's not busy.
      
      v2:
      - reword the third paragraph to clarify how the fix works (Peter Hurley)
      v3:
      - unchanged
      v4:
      - Allow unregistering a system console driver too, needed by i915 to
        unregister vgacon. Update commit description accordingly. (Daniel)
      Signed-off-by: NImre Deak <imre.deak@intel.com>
      Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      2cf30f75
  8. 26 11月, 2014 1 次提交
  9. 22 11月, 2014 1 次提交
  10. 06 11月, 2014 3 次提交
  11. 09 9月, 2014 1 次提交
  12. 07 6月, 2014 3 次提交
    • D
      vt: Don't ignore unbind errors in vt_unbind · f418f2ec
      Daniel Vetter 提交于
      Otherwise the loop will never stop since we don't make any
      forward progress. Noticed while breaking this accidentally
      in a painful attempt to make vga_con unregistering work.
      
      With this patch we'll bail out on the first attempt, which
      at least leaves a useful enough system behind for debugging.
      Livelocks on console_lock just aren't fun.
      
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Cc: Jiri Slaby <jslaby@suse.cz>
      Reviewed-by: NDavid Herrmann <dh.herrmann@gmail.com>
      Acked-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      f418f2ec
    • D
      vt: Fix up unregistration of vt drivers · d9c660e7
      Daniel Vetter 提交于
      A bunch of issues:
      - We should not kick out the default console (which is tracked in
        conswitchp), so check for that.
      - Add better error codes so callers can differentiate between "something
        went wrong" and "your driver isn't registered already". i915 needs
        that so it doesn't fall over when reloading the driver and hence
        vga_con is already unregistered.
      - There's a mess with the driver flags: What we need to check for is
        that the driver isn't used any more, i.e. unbound completely (FLAG_INIT).
        And not whether it's the boot console or not (which is the only one
        which doesn't have FLAG_MODULE). Otherwise there's no way to kick
        out the boot console, which i915 wants to do to prevent havoc with
        vga_con interferring (which tends to hang machines).
      
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Cc: Jiri Slaby <jslaby@suse.cz>
      Reviewed-by: NDavid Herrmann <dh.herrmann@gmail.com>
      Acked-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      d9c660e7
    • D
      vt: Fix replacement console check when unbinding · 249f7b3e
      Daniel Vetter 提交于
      I don't fully understand the magic of the vt register/unregister
      logic, but apparently everything but the inital console (as set
      in the conswitchp pointer) is marked with FLAG_MODULE. Which means
      if something unregistered the boot vt driver (e.g. i915.ko kicking
      out vga_con) there's nothing left when trying to unbind e.g. fbcon
      through sysfs.
      
      But in most cases have the dummy console hanging around besides the
      boot console, so this test is fairly dubious. What we actually want is
      simply a different console than the one we want to unbind.
      
      v2: Correct the commit message to clarify that the dummy console isn't
      always around, but only in most cases (David).
      
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Cc: Jiri Slaby <jslaby@suse.cz>
      Cc: David Herrmann <dh.herrmann@gmail.com>
      Reviewed-by: NDavid Herrmann <dh.herrmann@gmail.com>
      Acked-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      249f7b3e
  13. 29 5月, 2014 3 次提交
  14. 01 3月, 2014 2 次提交
    • A
      vt: detect and ignore OSC codes. · 63f3a16d
      Adam Borowski 提交于
      These can be used to send commands consisting of an arbitrary string to the
      terminal, most often used to set a terminal's window title or to redefine
      the colour palette.  Our console doesn't use OSC, unlike everything else,
      which can lead to junk being displayed if a process sends such a code
      unconditionally.
      
      The rules for termination follow established practice rather than Ecma-48.
      Ecma-48 requires the string to use only byte values 0x08..0x0D and
      0x20..0x7E, terminated with either ESC \ or 0x9C.  This would disallow using
      8-bit characters, which are reasonable for example in window titles.
      A widespread idiom is to terminate with 0x07.  The behaviour for other
      control characters differs between terminal emulators, I followed libvte and
      xterm:
      * 0x07 and ESC anything terminate
      * nothing else terminates, all 8-bit values including 0x9C are considered a
        part of the string
      Signed-off-by: NAdam Borowski <kilobyte@angband.pl>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      63f3a16d
    • A
      b290af68
  15. 14 2月, 2014 1 次提交
  16. 27 9月, 2013 2 次提交
  17. 05 8月, 2013 1 次提交
    • C
      vt: make the default color configurable · 3855ae1c
      Clemens Ladisch 提交于
      The virtual console has (undocumented) module parameters to set the
      colors for italic and underlined text, but the default text color was
      hardcoded for some reason.  This made it impossible to change the color
      for startup messages, or to set the default for new virtual consoles.
      Add a module parameter for that, and document the entire bunch.
      
      Any hacker who thinks that a command prompt on a "black screen with
      white font" is not supicious enough can now use the kernel parameter
      vt.color=10 to get a nice, evil green.
      Signed-off-by: NClemens Ladisch <clemens@ladisch.de>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      3855ae1c
  18. 27 7月, 2013 1 次提交
  19. 24 7月, 2013 3 次提交
    • P
      tty: Fix unsafe vt paste_selection() · a7c8d58c
      Peter Hurley 提交于
      Convert the tty_buffer_flush() exclusion mechanism to a
      public interface - tty_buffer_lock/unlock_exclusive() - and use
      the interface to safely write the paste selection to the line
      discipline.
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      a7c8d58c
    • P
      tty: Convert termios_mutex to termios_rwsem · 6a1c0680
      Peter Hurley 提交于
      termios is commonly accessed unsafely (especially by N_TTY)
      because the existing mutex forces exclusive access.
      Convert existing usage.
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      6a1c0680
    • P
      tty: Make ldisc input flow control concurrency-friendly · 24a89d1c
      Peter Hurley 提交于
      Although line discipline receiving is single-producer/single-consumer,
      using tty->receive_room to manage flow control creates unnecessary
      critical regions requiring additional lock use.
      
      Instead, introduce the optional .receive_buf2() ldisc method which
      returns the # of bytes actually received. Serialization is guaranteed
      by the caller.
      
      In turn, the line discipline should schedule the buffer work item
      whenever space becomes available; ie., when there is room to receive
      data and receive_room() previously returned 0 (the buffer work
      item stops processing if receive_buf2() returns 0). Note the
      'no room' state need not be atomic despite concurrent use by two
      threads because only the buffer work thread can set the state and
      only the read() thread can clear the state.
      
      Add n_tty_receive_buf2() as the receive_buf2() method for N_TTY.
      Provide a public helper function, tty_ldisc_receive_buf(), to use
      when directly accessing the receive_buf() methods.
      
      Line disciplines not using input flow control can continue to set
      tty->receive_room to a fixed value and only provide the receive_buf()
      method.
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      24a89d1c
  20. 29 6月, 2013 1 次提交
  21. 18 6月, 2013 1 次提交
  22. 21 5月, 2013 1 次提交