Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp235411ybe; Tue, 3 Sep 2019 21:42:14 -0700 (PDT) X-Google-Smtp-Source: APXvYqwgetX+/R+mAje4RF7kQJmup3VMO+8yKMmTb61ZEb9kAQVj/yYGbsv+XLfV8DxkQgEFq+bb X-Received: by 2002:a62:14c2:: with SMTP id 185mr18481415pfu.47.1567572134214; Tue, 03 Sep 2019 21:42:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567572134; cv=none; d=google.com; s=arc-20160816; b=cRCse5pY0loPAMXF/shCuoP6dFkIQUgk/jwo70KhvG502oiQzwuwl7kdgq+Z2urJeO txhUKNSYjLE14UY6tY5sZ1lIvQdlFenzBRdhGSyfW3AG8rpb7Zyr0h/dXZvCp+TCwv3r XvMmIr7SbCuL/BP+km8JT3e5PT6d3a/rplZjpXBOAmGthmXFBVIM81vEWRcMKC8MPDZU ycdg8A3jAhiDanrmAmqCLsR/Ai19z3Dr3fBvcKH0kyRotY9COMqQ2EqE/slNeBk+4ZrZ X1kU9k97uCqXAk0wTl6RrWfYu95vkwk3JKaU9cDS+NF+Wo4vPe9aBAF3P8iKf4YMT3u3 L0Nw== 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=rCfo8ZTPLFD1J9LanJqx/ih06mAfCjEXW/qtymlzmaY=; b=yk4WZC+y9XO2c806XES1wEKNxfJWHSB3egNw17KAkM+yIOWobeWAnjjWPZPjwYDeST HgourIYoIZl3ePF2org85p0cA6tTeLtEJvF9tZdF/bqgRncBJavWM6pIZj36JT8wWDRz XghLWs9ZSMkjBUbCalbbdxivZSpglAUNqTERKqWDmVlnliTnlicGW15Rg0Sdo8rHO183 cNdO6g4iZVSem9e0COiAvKk1r+8XImiK8taBboThdWaaBHuT7cB3asds7Dx2vADzR0XK dOdLn0exmt+Vbn+454J9h1x9ed+WT51IbjpuFhVWrOUlvfXoTyAE+qXbb4Kw8K/ajWMk l+CQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@endlessm-com.20150623.gappssmtp.com header.s=20150623 header.b=nNUzE22s; 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 y10si5094576plr.89.2019.09.03.21.41.56; Tue, 03 Sep 2019 21:42:14 -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=nNUzE22s; 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 S1727716AbfIDEih (ORCPT + 99 others); Wed, 4 Sep 2019 00:38:37 -0400 Received: from mail-qt1-f182.google.com ([209.85.160.182]:41387 "EHLO mail-qt1-f182.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725840AbfIDEig (ORCPT ); Wed, 4 Sep 2019 00:38:36 -0400 Received: by mail-qt1-f182.google.com with SMTP id j10so5273704qtp.8 for ; Tue, 03 Sep 2019 21:38:36 -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=rCfo8ZTPLFD1J9LanJqx/ih06mAfCjEXW/qtymlzmaY=; b=nNUzE22szLB6fIHBMR61HcFOyBi2VxuEnTbkYKcFzTfAR0nkrN45m6Of3tnpFA2oyx P1fi4etH/iQsP64d4b0YNZlnLtUlvmEHAgNlv66WbzKe+8hmp7jUpcRvHOuDj5i0FLU3 A3HVwuRPEMedPMCsVK5PH0596ZxTw9AkeUxaZOlFEBRtYx83g+ZOEE/OV5cRlC3r4r7a gf8CohZBRIO4k48aQnrWZDr/m9fQ3BsOpyj4KcC0VmY768nqdBJtX/njhT0kB4h21Due SxBimvqXPlVileAF76Tzhf6zGehsrzX/zAWBFjDRoPinSnt8+/kxRe3juVV0snbQlQ8Y pcOQ== 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=rCfo8ZTPLFD1J9LanJqx/ih06mAfCjEXW/qtymlzmaY=; b=L00wLmqASJbeQSi46pKpQjrNi7AYbDFElJ38xQPNFFsT6ep7+Zd9xSswoWbmNaf7iO zHaD5TqpSiKIAtbyHLcCO9xS/zePdlJUEpYEsdCkYyuB3W8OfZfBnXFv3LBEUwt1W30h OKb2PFvgm6b7YMGnttKGhKyl1lYf9X8iXbImXsdCjV+48qiWoHB5xyhuDxv1rmYec6qE QKqIlnUnNraXVcdlbz/TS9ByUPp/9grvfvp1ytqRh5SZmkwowDmHscCqVX4QWnOWYExT UnWkfzwhjUR48bI1v+9GFlTSGic7vtee8IPdOnpHC8dkCy7AkIoznsICaBOHgu+E4D7q MLYA== X-Gm-Message-State: APjAAAXIpq5/ycUyWlUD7+58+ZwfV9mJcaSNppuj09bXbjKJSAfZQhHb oXpMCiwR7E7eNLdIZkBS+fiaLhIRcZnYzSsvmAmPMQ== X-Received: by 2002:ac8:7959:: with SMTP id r25mr37347795qtt.208.1567571915575; Tue, 03 Sep 2019 21:38:35 -0700 (PDT) MIME-Version: 1.0 References: <20190903081858.GA2691@lahna.fi.intel.com> <3141a819-5964-4082-6f05-1926e16468b4@linux.intel.com> In-Reply-To: <3141a819-5964-4082-6f05-1926e16468b4@linux.intel.com> From: Chris Chiu Date: Wed, 4 Sep 2019 12:38:24 +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 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. Chris