Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp311137ybe; Tue, 3 Sep 2019 23:26:00 -0700 (PDT) X-Google-Smtp-Source: APXvYqx65hLyNLlrzvQti+KBj0FzH0Ee7W2v/utr4NWYXzn1WvinqDKBf3QO30h1vhcRW+bBG05U X-Received: by 2002:a62:d14c:: with SMTP id t12mr11052223pfl.185.1567578360287; Tue, 03 Sep 2019 23:26:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567578360; cv=none; d=google.com; s=arc-20160816; b=g/w5Gj+Vqq5wiLqQKvry0A2de/MViCTR6jSlaK9ZUnV9T7Jgz7BLYXtAe6SZk9xRFd wFz7wR+HtkHrBy4SC8xglin7gE7n02qDKHPXCP/6YgU5f6AOz3Ki/Q+8lxkRgE3AfllH fD83Pb3kTZYRnUklAraIoC/2pkBr1I9eihCesFsI0NfUHVIeGpAQql8eMcgs8X9fQ3SU evloYita6Ai+ZWxJBgX/i+18yFdZ2++tFA6WFtiBhcLb6shiCQOapbFiUkfHElLLq7Rq n2kxipGgUyoWam+XaFGDVicQTtRUfBmBSWSXq44ZBEDdu70BpiKp021w/ZLi9CjEYNJb 4Nlg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=Di+GnDQ2TnjFeODH4tBfbLUz3tcQ/aVDZSgnwbe0+G4=; b=ugc+rml8WoZv0Y4V4KaNbXWseA56qYD5DTGIlNvlgYAKKgdCGLTskEXTdUKAacAXRE gKxDvxmfcsbQlGx9iVHsjAqxEVU/T/ioalh//cMox901hZtABI6UkmA9m9kKKTLBUrUI VOThJS29STl7xMGaSyQOMzFNrAeJa60aq68H80TEcB0V0nQ/D2YcB9OfmQa2kRgn4Pcf Prcz6z6+ac8xb562sPBL/Q+xbLCdo79le8r9Zu28OCPuu403GXfS6U/F5S8Pjp6HHCr2 XhjiolHzmvZtlHrcBHImEOahbnsPg3moBartEFcPZD/v29OgxH9EX0U4x/vjYnhwhKa3 q+9w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@endlessm-com.20150623.gappssmtp.com header.s=20150623 header.b=sw34W2ei; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e3si1540680pjr.26.2019.09.03.23.25.44; Tue, 03 Sep 2019 23:26:00 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@endlessm-com.20150623.gappssmtp.com header.s=20150623 header.b=sw34W2ei; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728525AbfIDGYi (ORCPT + 99 others); Wed, 4 Sep 2019 02:24:38 -0400 Received: from mail-qk1-f170.google.com ([209.85.222.170]:39197 "EHLO mail-qk1-f170.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728108AbfIDGYi (ORCPT ); Wed, 4 Sep 2019 02:24:38 -0400 Received: by mail-qk1-f170.google.com with SMTP id 4so18582464qki.6 for ; Tue, 03 Sep 2019 23:24:37 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=endlessm-com.20150623.gappssmtp.com; s=20150623; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=Di+GnDQ2TnjFeODH4tBfbLUz3tcQ/aVDZSgnwbe0+G4=; b=sw34W2eiN25sNXFeN8XcPZRfTjzJ9WiqbXI5QElU4GEHV0DY73/iysR6tIrZ5bj+ru N1q/jf5kMqw1WKASyIXUaNZmXjxynGDYh2Ps/g/K65gB3aoqH0etGpva9cEuTEZ9yAmL NPOFGy1sTDIIhwkCChDz+AZG+gQs2aoBKoC9JPUXzhDVN9R665r3rFtmQAALZfJcG7Qr /A0utUCvrMzmh5iGkW4tB+Rp0DujmxCblXA6pAePmnQUNM7SdsoWZEmv4/fWk3qK933a bxA5GdJt2LonHiE+xKiv16/eHTalLMFJryARg1fN1GCrBkj/NmB1vVbHQuY2q/MMXd5m pBMQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=Di+GnDQ2TnjFeODH4tBfbLUz3tcQ/aVDZSgnwbe0+G4=; b=DWNQh+7eTs0nsEKzTFYfRPKdFfW6h0cMB+l1mGJbSiHosqGDUgUUrE9hE1IzOBpBrK IjCWy90BE5v8zWfQbzJSg/Q9EwFwqXBhRuWYCmyEtfKc3VqBQkoBrTP+lz0Dvs3WssmE dj36lIVpPjT1K+HyPxMq/5gFWxGNEyXbFesIYOfL+h5pXLVh4qhRvfMqxMhIdGReNv39 aIStRJqqxLMTEHDWtJwzsVDFGUW67FRXoAC6GIMJG+DkQHITcIkclA/WJNFxEu43xyEC /xC1N57j3P8R4n+smtM7/N0WiB93tMJHKHxd73qsvZc4dQNSrvJZQkeYDrX5PZ9tm/Wb iUQQ== X-Gm-Message-State: APjAAAVunWUnEKhvR3Q7G256ItIVZ/YlCVqPNjQXp2hTFszabOKcx2wT buPBXxUbcWGsYZRyzijD0CWHhFkwXYapXWI7VmspqQ== X-Received: by 2002:a05:620a:5ad:: with SMTP id q13mr20244042qkq.297.1567578276980; Tue, 03 Sep 2019 23:24:36 -0700 (PDT) MIME-Version: 1.0 References: <20190903081858.GA2691@lahna.fi.intel.com> <3141a819-5964-4082-6f05-1926e16468b4@linux.intel.com> <63364b2f-dc55-4fcb-5de5-d09c9622943a@linux.intel.com> In-Reply-To: <63364b2f-dc55-4fcb-5de5-d09c9622943a@linux.intel.com> From: Chris Chiu Date: Wed, 4 Sep 2019 14:24:26 +0800 Message-ID: Subject: Re: Tweak I2C SDA hold time on GemniLake to make touchpad work To: Jarkko Nikula Cc: Mika Westerberg , Andy Shevchenko , lee.jones@linaro.org, Linux Kernel , Linux Upstreaming Team Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Sep 4, 2019 at 1:54 PM Jarkko Nikula wrote: > > On 9/4/19 7:38 AM, Chris Chiu wrote: > > On Tue, Sep 3, 2019 at 8:03 PM Jarkko Nikula > > wrote: > >> > >> Hi Chris > >> > >> On 9/3/19 11:18 AM, Mika Westerberg wrote: > >>> +Jarkko > >>> > >>> On Tue, Sep 03, 2019 at 04:10:27PM +0800, Chris Chiu wrote: > >>>> Hi, > >>>> > >>>> We're working on the acer Gemnilake laptop TravelMate B118-M for > >>>> touchpad not working issue. The touchpad fails to bring up and the > >>>> i2c-hid ouput the message as follows > >>>> [ 8.317293] i2c_hid i2c-ELAN0502:00: hid_descr_cmd failed > >>>> We tried on latest linux kernel 5.3.0-rc6 and it reports the same. > >>>> > >>>> We then look into I2C signal level measurement to find out why. > >>>> The following is the signal output from LA for the SCL/SDA. > >>>> https://imgur.com/sKcpvdo > >>>> The SCL frequency is ~400kHz from the SCL period, but the SDA > >>>> transition is quite weird. Per the I2C spec, the data on the SDA line > >>>> must be stable during the high period of the clock. The HIGH or LOW > >>>> state of the data line can only change when the clock signal on the > >>>> SCL line is LOW. The SDA period span across 2 SCL high, I think > >>>> that's the reason why the I2C read the wrong data and fail to initialize. > >>>> > >>>> Thus, we treak the SDA hold time by the following modification. > >>>> > >>>> --- a/drivers/mfd/intel-lpss-pci.c > >>>> +++ b/drivers/mfd/intel-lpss-pci.c > >>>> @@ -97,7 +97,8 @@ static const struct intel_lpss_platform_info bxt_uart_info = { > >>>> }; > >>>> > >>>> static struct property_entry bxt_i2c_properties[] = { > >>>> - PROPERTY_ENTRY_U32("i2c-sda-hold-time-ns", 42), > >>>> + PROPERTY_ENTRY_U32("i2c-sda-hold-time-ns", 230), > >>>> PROPERTY_ENTRY_U32("i2c-sda-falling-time-ns", 171), > >>>> PROPERTY_ENTRY_U32("i2c-scl-falling-time-ns", 208), > >>>> { }, > >>>> > >>>> The reason why I choose sda hold time is by the Table 10 of > >>>> https://www.nxp.com/docs/en/user-guide/UM10204.pdf, the device > >>>> must provide a hold time at lease 300ns and and 42 here is relatively > >>>> too small. The signal measurement result for the same pin on Windows > >>>> is as follows. > >>>> https://imgur.com/BtKUIZB > >>>> Comparing to the same result running Linux > >>>> https://imgur.com/N4fPTYN > >>>> > >>>> After applying the sda hold time tweak patch above, the touchpad can > >>>> be correctly initialized and work. The LA signal is shown as down below. > >>>> https://imgur.com/B3PmnIp > >>>> > >> Could you try does attached patch work for you? > >> > >> It's from last year for another related issue but there platform was > >> actually Apollo Lake instead of Gemini Lake but anyway it was found out > >> that Windows uses different timing parameters than Linux on Gemini Lake. > >> > >> I didn't take patch forward back then due known Gemini Lake machines > >> were working with the Broxton I2C timing parameters but now it's time if > >> attached patch fixes the issue on your machine. > >> > >> Patch is from top of v5.3-rc7 but should probably apply also to older > >> kernels. > >> > >> -- > >> Jarkko > > > > Thanks, Jarkko, the patche works on my acer laptops. > > > Thanks. I'll send the patch out with Cc'ing you. I took the freedom to > add your Tested-by tag if you don't mind :-) > > -- > Jarkko No problem. Thanks