Date: Mon, 10 Oct 2016 23:01:59 +0300 From: Andriy Gapon <avg@FreeBSD.org> To: Michael Gmelin <grembo@FreeBSD.org>, Matthias Apitz <guru@unixarea.de> Cc: Warner Losh <imp@bsdimp.com>, FreeBSD Current <freebsd-current@FreeBSD.org> Subject: Re: [request for testing] isl, cyapa on chromebooks Message-ID: <a53b8950-f1e1-1227-c2bd-ce195a158b90@FreeBSD.org> In-Reply-To: <63DC842D-48EC-4A5F-938F-AF8CE1E37BF8@freebsd.org> References: <d4501bd4-7b53-0fb7-ab89-f721368f3f04@FreeBSD.org> <20161008180742.GA1912@c720-r292778-amd64> <846bf31f-a757-2be0-a293-8c4ce3d42a2f@FreeBSD.org> <CANCZdfrYhczHJHR3Kq8GSFx5c_6hcrK=1HU12PXcVB-WAo-8QA@mail.gmail.com> <20161009015324.007a7b42@bsd64.grem.de> <20161009065423.GA2012@c720-r292778-amd64> <CANCZdfrSgKv7Gs6hjd8MOH1cb9UyFcMuJQUkUkMvKxtuUYawRA@mail.gmail.com> <23c6b4f0-77e9-fe90-0eed-9d0125e7624b@FreeBSD.org> <20161010134610.32120b55@bsd64.grem.de> <CANCZdfppv==6FKSACKwGCyen2yWik-Kkp78Yh=d6a7ZaPUMkUQ@mail.gmail.com> <20161010182710.GA1956@c720-r292778-amd64> <63DC842D-48EC-4A5F-938F-AF8CE1E37BF8@freebsd.org>
next in thread | previous in thread | raw e-mail | index | archive | help
On 10/10/2016 21:45, Michael Gmelin wrote: > I see three tasks here: - Andriy finishes his change, moving things from > smbus to iicbus, adding some workaround to keep the user experience like it > is - Someone else implements the device table mechanism for auto detection - > Someone else ports HDI over I2C to allow implementing drivers for devices > like the elan touchpad Matthias is referring to > > Makes sense? It does to me. Also, I can suggest another task related to SMBus / I2C. Looking at the code in the Linux chromeos_laptop driver I see that on some models some sensors are actually attached to SMBus rather that to I2C. And, for example, cyapa can be attached to either bus. But there is a quirk. cyapa won't work over a standard SMBus, it needs some extensions that are typically provided by Intel chipsets. I specifically mean the so called "I2C Block Read" and the transaction that results from the Block Write command when the I2C bit is set in the SMBus controller's configuration register. Neither of these modes is supported by our ichsmb(4) driver. But on Linux they are both supported and exposed as I2C_SMBUS_I2C_BLOCK_DATA transaction type. For one reference please see Mobile 4th Generation IntelĀ® CoreTM Processor Family I/O Datasheet, section 5.21.1.1. And, just in case, ig4(4) is about the controllers described in section 5.22 of that document. Perhaps, I2C_SMBUS_I2C_BLOCK_DATA served as an inspiration (and perhaps a source of confusion) for Matt when he added smbus_trans(). Right now I do not have any good suggestion on how to expose that 90% SMBus, 10% I2C functionality in the FreeBSD model. -- Andriy Gapon
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?a53b8950-f1e1-1227-c2bd-ce195a158b90>
