1. 30 5月, 2011 1 次提交
  2. 27 5月, 2011 3 次提交
  3. 26 5月, 2011 2 次提交
  4. 23 5月, 2011 1 次提交
    • P
      apm-emulation: apm_mutex breaks ACK; remove it · fda5fe19
      Paul Parsons 提交于
      apm_mutex is locked by a process (e.g. apm -s) at the start of apm_ioctl() and
      remains locked while pm_suspend() is called. Any subsequent process trying to
      ACK the suspend (e.g. apmd) is then blocked at the start of apm_ioctl(),
      causing the suspend to be delayed for 5 seconds in apm_suspend_notifier()
      while the ACK times out. In short, ACKs don't work.
      
      The driver's data structures are sufficiently protected by assorted locks. And
      pm_suspend() has its own mutex to prevent reentrancy. Consequently there is no
      obvious requirement for apm_mutex, which evolved from earlier BKL calls. So
      let's remove it.
      Signed-off-by: NPaul Parsons <lost.distance@yahoo.com>
      Acked-by: NRafael J. Wysocki <rjw@sisk.pl>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      fda5fe19
  5. 22 5月, 2011 1 次提交
  6. 19 5月, 2011 1 次提交
    • G
      drivercore: revert addition of of_match to struct device · b1608d69
      Grant Likely 提交于
      Commit b826291c, "drivercore/dt: add a match table pointer to struct
      device" added an of_match pointer to struct device to cache the
      of_match_table entry discovered at driver match time.  This was unsafe
      because matching is not an atomic operation with probing a driver.  If
      two or more drivers are attempted to be matched to a driver at the
      same time, then the cached matching entry pointer could get
      overwritten.
      
      This patch reverts the of_match cache pointer and reworks all users to
      call of_match_device() directly instead.
      Signed-off-by: NGrant Likely <grant.likely@secretlab.ca>
      b1608d69
  7. 14 5月, 2011 1 次提交
  8. 07 5月, 2011 2 次提交
  9. 06 5月, 2011 1 次提交
  10. 04 5月, 2011 3 次提交
  11. 21 4月, 2011 3 次提交
    • A
      virtio: console: Enable call to hvc_remove() on console port remove · afa2689e
      Amit Shah 提交于
      This call was disabled as hot-unplugging one virtconsole port led to
      another virtconsole port freezing.
      
      Upon testing it again, this now works, so enable it.
      
      In addition, a bug was found in qemu wherein removing a port of one type
      caused the guest output from another port to stop working.  I doubt it
      was just this bug that caused it (since disabling the hvc_remove() call
      did allow other ports to continue working), but since it's all solved
      now, we're fine with hot-unplugging of virtconsole ports.
      Signed-off-by: NAmit Shah <amit.shah@redhat.com>
      Signed-off-by: NRusty Russell <rusty@rustcorp.com.au>
      afa2689e
    • V
      agp: fix arbitrary kernel memory writes · 194b3da8
      Vasiliy Kulikov 提交于
      pg_start is copied from userspace on AGPIOC_BIND and AGPIOC_UNBIND ioctl
      cmds of agp_ioctl() and passed to agpioc_bind_wrap().  As said in the
      comment, (pg_start + mem->page_count) may wrap in case of AGPIOC_BIND,
      and it is not checked at all in case of AGPIOC_UNBIND.  As a result, user
      with sufficient privileges (usually "video" group) may generate either
      local DoS or privilege escalation.
      Signed-off-by: NVasiliy Kulikov <segoon@openwall.com>
      Signed-off-by: NDave Airlie <airlied@redhat.com>
      194b3da8
    • V
      agp: fix OOM and buffer overflow · b522f021
      Vasiliy Kulikov 提交于
      page_count is copied from userspace.  agp_allocate_memory() tries to
      check whether this number is too big, but doesn't take into account the
      wrap case.  Also agp_create_user_memory() doesn't check whether
      alloc_size is calculated from num_agp_pages variable without overflow.
      This may lead to allocation of too small buffer with following buffer
      overflow.
      
      Another problem in agp code is not addressed in the patch - kernel memory
      exhaustion (AGPIOC_RESERVE and AGPIOC_ALLOCATE ioctls).  It is not checked
      whether requested pid is a pid of the caller (no check in agpioc_reserve_wrap()).
      Each allocation is limited to 16KB, though, there is no per-process limit.
      This might lead to OOM situation, which is not even solved in case of the
      caller death by OOM killer - the memory is allocated for another (faked) process.
      Signed-off-by: NVasiliy Kulikov <segoon@openwall.com>
      Signed-off-by: NDave Airlie <airlied@redhat.com>
      b522f021
  12. 20 4月, 2011 2 次提交
  13. 31 3月, 2011 1 次提交
  14. 30 3月, 2011 1 次提交
  15. 24 3月, 2011 3 次提交
  16. 17 3月, 2011 1 次提交
  17. 11 3月, 2011 1 次提交
  18. 08 3月, 2011 2 次提交
  19. 07 3月, 2011 1 次提交
  20. 02 3月, 2011 2 次提交
  21. 01 3月, 2011 2 次提交
  22. 28 2月, 2011 2 次提交
  23. 26 2月, 2011 1 次提交
  24. 24 2月, 2011 1 次提交
  25. 23 2月, 2011 1 次提交