1. 21 4月, 2012 1 次提交
  2. 12 12月, 2011 1 次提交
  3. 16 11月, 2011 1 次提交
    • D
      Input: synaptics - update OLPC XO exclusion · 83551c01
      Daniel Drake 提交于
      We have determined that the jumpiness previously seen when using
      the synaptics kernel mouse driver on OLPC XO was due to not using
      the synaptics X11 userspace driver - the xf86-input-evdev driver was
      interpreting 'finger near pad' signals as movements. Newer versions
      of xf86-input-evdev fix this issue.
      
      Additionally, the synaptics kernel driver is now usable on this
      platform, but only when run in relative mode.
      
      Update the comment and refine the check to allow the synaptics driver
      to run on OLPC XO in relative mode.
      
      We will continue investigating the EC issue as time becomes available.
      Signed-off-by: NDaniel Drake <dsd@laptop.org>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      83551c01
  4. 10 11月, 2011 1 次提交
    • D
      Input: synaptics - add support for Relative mode · 7968a5dd
      Daniel Drake 提交于
      Currently, the synaptics driver puts the device into Absolute mode.
      As explained in the synaptics documentation section 3.2, in this mode,
      the device sends a continuous stream of packets at the maximum rate
      to the host when the user's fingers are near or on the pad or
      pressing buttons, and continues streaming for 1 second afterwards.
      These packets are even sent when there is no new information to report,
      even when they are duplicates of the previous packet.
      
      For embedded systems this is a bit much - it results in a huge
      and uninterrupted stream of interrupts at high rate.
      
      This patch adds support for Relative mode, which can be selected as
      a new psmouse protocol. In this mode, the device does not send duplicate
      packets and acts like a standard PS/2 mouse. However, synaptics-specific
      functionality is still available, such as the ability to set the packet
      rate, and rather than disabling gestures and taps at the hardware level
      unconditionally, a 'synaptics_disable_gesture' sysfs attribute has
      been added to allow control of this functionality.
      
      This solves a long standing OLPC issue: synaptics hardware enables
      tap to click by default (even in the default relative mode), but we
      have found this to be inappropriate for young children and first
      time computer users. Enabling the synaptics driver disables tap-to-click,
      but we have previously been unable to use this because it also enables
      Absolute mode, which is too "spammy" for our desires and actually
      overloads our EC with its continuous stream of packets. Now we can enable
      the synaptics driver, disabling tap to click while retaining the less
      noisy Relative mode.
      Signed-off-by: NDaniel Drake <dsd@laptop.org>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      7968a5dd
  5. 11 10月, 2011 1 次提交
  6. 24 8月, 2011 7 次提交
    • D
      Input: synaptics - process finger (<=5) transitions · 6b4b49fe
      Daniel Kurtz 提交于
      Synaptics image sensor touchpads track up to 5 fingers, but only report 2.
      They use a special "TYPE=2" (AGM-CONTACT) packet type that reports
      the number of tracked fingers and which finger is reported in the SGM
      and AGM packets.
      
      With this new packet type, it is possible to tell userspace when 4 or 5
      fingers are touching.
      Signed-off-by: NDaniel Kurtz <djkurtz@chromium.org>
      Acked-by: NChase Douglas <chase.douglas@canonical.com>
      Acked-by: NHenrik Rydberg <rydberg@euromail.se>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      6b4b49fe
    • D
      Input: synaptics - process finger (<=3) transitions · 4dc772d2
      Daniel Kurtz 提交于
      Synaptics image sensor touchpads track 5 fingers, but only report 2.
      This patch attempts to deal with some idiosyncrasies of these touchpads:
      
       * When there are 3 or more fingers, only two are reported.
       * The touchpad tracks the 5 fingers in slot[0] through slot[4].
       * It always reports the lowest and highest valid slots in SGM and AGM
         packets, respectively.
       * The number of fingers is only reported in the SGM packet.  However,
         the number of fingers can change either before or after an AGM
         packet.
       * Thus, if an SGM reports a different number of fingers than the last
         SGM, it is impossible to tell whether the intervening AGM corresponds
         to the old number of fingers or the new number of fingers.
       * For example, when going from 2->3 fingers, it is not possible to tell
         whether tell AGM contains slot[1] (old 2nd finger) or slot[2] (new
         3rd finger).
       * When fingers are added one at at time, from 1->2->3, it is possible to
         track which slots are contained in the SGM and AGM packets:
           1 finger:  SGM = slot[0], no AGM
           2 fingers: SGM = slot[0], AGM = slot[1]
           3 fingers: SGM = slot[0], AGM = slot[2]
       * It is also possible to track which slot is contained in the SGM when 1
         of 2 fingers is removed.  This is because the touchpad sends a special
         (0,0,0) AGM packet whenever all fingers are removed except slot[0]:
           Last AGM == (0,0,0): SGM contains slot[1]
           Else: SGM contains slot[0]
       * However, once there are 3 fingers, if exactly 1 finger is removed, it
         is impossible to tell which 2 slots are contained in SGM and AGM.
         The (SGM,AGM) could be (0,1), (0,2), or (1,2). There is no way to know.
       * Similarly, if two fingers are simultaneously removed (3->1), then it
         is only possible to know if SGM still contains slot[0].
       * Since it is not possible to reliably track which slot is being
         reported, we invalidate the tracking_id every time the number of
         fingers changes until this ambiguity is resolved when:
           a) All fingers are removed.
           b) 4 or 5 fingers are touched, generates an AGM-CONTACT packet.
           c) All fingers are removed except slot[0].  In this special case, the
              ambiguity is resolved since by the (0,0,0) AGM packet.
      
      Behavior of the driver:
      
      When 2 or more fingers are present on the touchpad, the kernel reports
      up to two MT-B slots containing the position data for two of the fingers
      reported by the touchpad.  If the identity of a finger cannot be tracked
      when the number-of-fingers changes, the corresponding MT-B slot will be
      invalidated (track_id set to -1), and a new track_id will be assigned in
      a subsequent input event report.
      
      The driver always reports the total number of fingers using one of the
      EV_KEY/BTN_TOOL_*TAP events. This could differ from the number of valid
      MT-B slots for two reasons:
       a) There are more than 2 fingers on the pad.
       b) During ambiguous number-of-fingers transitions, the correct track_id
          for one or both of the slots cannot be determined, so the slots are
          invalidated.
      
      Thus, this is a hybrid singletouch/MT-B scheme. Userspace can detect
      this behavior by noting that the driver supports more EV_KEY/BTN_TOOL_*TAP
      events than its maximum EV_ABS/ABS_MT_SLOT.
      Signed-off-by: NDaniel Kurtz <djkurtz@chromium.org>
      Acked-by: NChase Douglas <chase.douglas@canonical.com>
      Acked-by: NHenrik Rydberg <rydberg@euromail.se>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      4dc772d2
    • D
      Input: synaptics - decode AGM packet types · a6ca40c1
      Daniel Kurtz 提交于
      A Synaptics image sensor tracks 5 fingers, but can only report 2.
      
      The algorithm for choosing which 2 fingers to report and in which packet:
        Touchpad maintains 5 slots, numbered 0 to 4
        Initially all slots are empty
        As new fingers are detected, assign them to the lowest available slots
        The touchpad always reports:
          SGM: lowest numbered non-empty slot
          AGM: highest numbered non-empty slot, if there is one
      
      In addition, these touchpads have a special AGM packet type which reports
      the number of fingers currently being tracked, and which finger is in
      each of the two slots.  Unfortunately, these "TYPE=2" packets are only used
      when more than 3 fingers are being tracked.  When less than 4 fingers
      are present, the 'w' value must be used to track how many fingers are
      present, and knowing which fingers are being reported is much more
      difficult, if not impossible.
      Signed-off-by: NDaniel Kurtz <djkurtz@chromium.org>
      Acked-by: NChase Douglas <chase.douglas@canonical.com>
      Acked-by: NHenrik Rydberg <rydberg@euromail.se>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      a6ca40c1
    • D
      Input: synaptics - add image sensor support · 3cdfee9e
      Daniel Kurtz 提交于
      Synaptics makes (at least) two kinds of touchpad sensors:
       * Older pads use a profile sensor that could only infer the location
         of individual fingers based on the projection of their profiles
         onto row and column sensors.
       * Newer pads use an image sensor that can track true finger position
         using a two-dimensional sensor grid.
      
      Both sensor types support an "Advanced Gesture Mode":
       When multiple fingers are detected, the touchpad sends alternating
       "Advanced Gesture Mode" (AGM) and "Simple Gesture Mode" (SGM)
       packets.
       The AGM packets have w=2, and contain reduced resolution finger data
       The SGM packets have w={0,1} and contain full resolution finger data
      
      Profile sensors try to report the "upper" (larger y value) finger in
      the SGM packet, and the lower (smaller y value) in the AGM packet.
      However, due to the nature of the profile sensor, they easily get
      confused when fingers cross, and can start reporting the x-coordinate
      of one with the y-coordinate of the other.  Thus, for profile
      sensors, "semi-mt" was created, which reports a "bounding box"
      created by pairing min and max coordinates of the two pairs of
      reported fingers.
      
      Image sensors can report the actual coordinates of two of the fingers
      present.  This patch detects if the touchpad is an image sensor and
      reports finger data using the MT-B protocol.
      
      NOTE: This patch only adds partial support for 2-finger gestures.
            The proper interpretation of the slot contents when more than
            two fingers are present is left to later patches.  Also,
            handling of 'number of fingers' transitions is incomplete.
      Signed-off-by: NDaniel Kurtz <djkurtz@chromium.org>
      Acked-by: NChase Douglas <chase.douglas@canonical.com>
      Acked-by: NHenrik Rydberg <rydberg@euromail.se>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      3cdfee9e
    • D
    • D
      Input: synaptics - refactor agm packet parsing · 7afdb842
      Daniel Kurtz 提交于
      When a Synaptics touchpad is in "AGM" mode, and multiple fingers are
      detected, the touchpad sends alternating "Advanced Gesture Mode" (AGM) and
      "Simple Gesture Mode" (SGM) packets.
        The AGM packets have w=2, and contain reduced resolution finger data.
        The SGM packets have w={0,1} and contain full resolution finger data.
      
      Refactor the parsing of agm packets to its own function, and rename the
      synaptics_data.mt field to .agm to indicate that it contains the contents of
      the last agm packet.
      Signed-off-by: NDaniel Kurtz <djkurtz@chromium.org>
      Acked-by: NChase Douglas <chase.douglas@canonical.com>
      Acked-by: NHenrik Rydberg <rydberg@euromail.se>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      7afdb842
    • D
      Input: synaptics - refactor y inversion · 6de58dd6
      Daniel Kurtz 提交于
      Synaptics touchpads report increasing y from bottom to top.
      This is inverted from normal userspace "top of screen is 0" coordinates.
      Thus, the kernel driver reports inverted y coordinates to userspace.
      
      This patch refactors this inversion.
      Signed-off-by: NDaniel Kurtz <djkurtz@chromium.org>
      Acked-by: NChase Douglas <chase.douglas@canonical.com>
      Acked-by: NHenrik Rydberg <rydberg@euromail.se>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      6de58dd6
  7. 10 7月, 2011 1 次提交
  8. 07 7月, 2011 4 次提交
  9. 31 3月, 2011 1 次提交
  10. 29 1月, 2011 2 次提交
  11. 23 12月, 2010 2 次提交
  12. 22 12月, 2010 3 次提交
  13. 13 10月, 2010 2 次提交
  14. 03 8月, 2010 1 次提交
  15. 22 7月, 2010 1 次提交
  16. 20 7月, 2010 2 次提交
    • C
      Input: synaptics - set min/max for finger width · 58fb0218
      Chris Bagwell 提交于
      Reporting this will allow GUI config apps to correctly scale
      width sensitive config values (such as palm detect) to correct
      range.  Current user apps are detecting kernels min/max=0/0 and
      making an assumption that it means 0/16 or 0/15.
      
      Synaptics touchpad interface guides show 4/15 are correct values
      but driver forces to 0 when no fingers on touchpad.
      Signed-off-by: NChris Bagwell <chris@cnpbagwell.com>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      58fb0218
    • C
      Input: synaptics - only report width on hardware that supports it · 2a8e7710
      Chris Bagwell 提交于
      Synaptics devices report fixed value of 5 for finger/palm widths
      on devices that do not support capability and driver further
      hardcodes to 5.  Stop reporting this fixed value when its not
      supported since its not useful.
      
      This will aid applications so they can better auto-enable support
      for multi-touch emulation and palm detection logic using finger
      width only for devices that support width detection.
      
      I can find no applications that currently require existence on
      ABS_TOOL_WIDTH. Since only synaptics and bcm input devices
      currently support this tool, it seems they must handle it
      gracefully.
      Signed-off-by: NChris Bagwell <chris@cnpbagwell.com>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      2a8e7710
  17. 15 7月, 2010 1 次提交
  18. 20 5月, 2010 2 次提交
  19. 20 4月, 2010 1 次提交
    • T
      Input: Add support of Synaptics Clickpad device · 5f57d67d
      Takashi Iwai 提交于
      The new type of touchpads can be detected via a new query command
      0x0c. The clickpad flags are in cap[0]:4 and cap[1]:0 bits.
      
      When the device is detected, the driver now reports only the left
      button as the supported buttons so that X11 driver can detect that
      the device is Clickpad. A Clickpad device gives the button events
      only as the middle button. The kernel driver morphs to the left
      button. The real handling of Clickpad is done rather in X driver
      side.
      Signed-off-by: NTakashi Iwai <tiwai@suse.de>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      5f57d67d
  20. 30 3月, 2010 1 次提交
    • T
      include cleanup: Update gfp.h and slab.h includes to prepare for breaking... · 5a0e3ad6
      Tejun Heo 提交于
      include cleanup: Update gfp.h and slab.h includes to prepare for breaking implicit slab.h inclusion from percpu.h
      
      percpu.h is included by sched.h and module.h and thus ends up being
      included when building most .c files.  percpu.h includes slab.h which
      in turn includes gfp.h making everything defined by the two files
      universally available and complicating inclusion dependencies.
      
      percpu.h -> slab.h dependency is about to be removed.  Prepare for
      this change by updating users of gfp and slab facilities include those
      headers directly instead of assuming availability.  As this conversion
      needs to touch large number of source files, the following script is
      used as the basis of conversion.
      
        http://userweb.kernel.org/~tj/misc/slabh-sweep.py
      
      The script does the followings.
      
      * Scan files for gfp and slab usages and update includes such that
        only the necessary includes are there.  ie. if only gfp is used,
        gfp.h, if slab is used, slab.h.
      
      * When the script inserts a new include, it looks at the include
        blocks and try to put the new include such that its order conforms
        to its surrounding.  It's put in the include block which contains
        core kernel includes, in the same order that the rest are ordered -
        alphabetical, Christmas tree, rev-Xmas-tree or at the end if there
        doesn't seem to be any matching order.
      
      * If the script can't find a place to put a new include (mostly
        because the file doesn't have fitting include block), it prints out
        an error message indicating which .h file needs to be added to the
        file.
      
      The conversion was done in the following steps.
      
      1. The initial automatic conversion of all .c files updated slightly
         over 4000 files, deleting around 700 includes and adding ~480 gfp.h
         and ~3000 slab.h inclusions.  The script emitted errors for ~400
         files.
      
      2. Each error was manually checked.  Some didn't need the inclusion,
         some needed manual addition while adding it to implementation .h or
         embedding .c file was more appropriate for others.  This step added
         inclusions to around 150 files.
      
      3. The script was run again and the output was compared to the edits
         from #2 to make sure no file was left behind.
      
      4. Several build tests were done and a couple of problems were fixed.
         e.g. lib/decompress_*.c used malloc/free() wrappers around slab
         APIs requiring slab.h to be added manually.
      
      5. The script was run on all .h files but without automatically
         editing them as sprinkling gfp.h and slab.h inclusions around .h
         files could easily lead to inclusion dependency hell.  Most gfp.h
         inclusion directives were ignored as stuff from gfp.h was usually
         wildly available and often used in preprocessor macros.  Each
         slab.h inclusion directive was examined and added manually as
         necessary.
      
      6. percpu.h was updated not to include slab.h.
      
      7. Build test were done on the following configurations and failures
         were fixed.  CONFIG_GCOV_KERNEL was turned off for all tests (as my
         distributed build env didn't work with gcov compiles) and a few
         more options had to be turned off depending on archs to make things
         build (like ipr on powerpc/64 which failed due to missing writeq).
      
         * x86 and x86_64 UP and SMP allmodconfig and a custom test config.
         * powerpc and powerpc64 SMP allmodconfig
         * sparc and sparc64 SMP allmodconfig
         * ia64 SMP allmodconfig
         * s390 SMP allmodconfig
         * alpha SMP allmodconfig
         * um on x86_64 SMP allmodconfig
      
      8. percpu.h modifications were reverted so that it could be applied as
         a separate patch and serve as bisection point.
      
      Given the fact that I had only a couple of failures from tests on step
      6, I'm fairly confident about the coverage of this conversion patch.
      If there is a breakage, it's likely to be something in one of the arch
      headers which should be easily discoverable easily on most builds of
      the specific arch.
      Signed-off-by: NTejun Heo <tj@kernel.org>
      Guess-its-ok-by: NChristoph Lameter <cl@linux-foundation.org>
      Cc: Ingo Molnar <mingo@redhat.com>
      Cc: Lee Schermerhorn <Lee.Schermerhorn@hp.com>
      5a0e3ad6
  21. 07 1月, 2010 1 次提交
    • D
      Input: psmouse - fix Synaptics detection when protocol is disabled · e4e6efd2
      Daniel Drake 提交于
      For configurations where Synaptics hardware is present but the Synaptics
      extensions support is not compiled in, the mouse is reprobed and a new
      device is allocated on every suspend/resume.
      
      During probe, psmouse_switch_protocol() calls psmouse_extensions() with
      set_properties=1. This calls the dummy synaptics_init() which returns an
      error code, instructing us not to use the synaptics extensions.
      
      During resume, psmouse_reconnect() calls psmouse_extensions() with
      set_properties=0, in which case call to synaptics_init() is bypassed and
      PSMOUSE_SYNAPTICS is returned. Since the result is different from previous
      attempt psmouse_reconnect() fails and full re-probe happens.
      
      Fix this by tweaking the set_properties=0 codepath in psmouse_extensions()
      to be more careful about offering PSMOUSE_SYNAPTICS extensions.
      Signed-off-by: NDaniel Drake <dsd@laptop.org>
      Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
      e4e6efd2
  22. 05 12月, 2009 1 次提交
  23. 04 12月, 2009 1 次提交
  24. 13 10月, 2009 1 次提交