Re: [PATCH] platform/x86: x86-android-tablets: Add Lenovo Yoga Tab 3 (YT3-X90F) charger + fuel-gauge data

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sun, Nov 27, 2022 at 07:24:58PM +0100, Hans de Goede wrote:
> The Lenovo Yoga Tab 3 (YT3-X90F) is an Intel Cherry Trail based tablet
> which ships with Android as Factory OS. Its DSDT contains a bunch of I2C
> devices which are not actually there, causing various resource conflicts.
> Use acpi_quirk_skip_i2c_client_enumeration() to not enumerate these.
> 
> The YT3-X90F has quite a bit of exotic hardware, this adds initial
> support by manually instantiating the i2c-clients for the 2 charger +
> 2 fuel-gauge chips used for the 2 batteries.
> 
> Support for other parts of the hw will be added by follow-up patches.

...

> +	/*
> +	 * The "bq25892_0" charger IC has its /CE (Charge-Enable) and OTG pins
> +	 * connected to GPIOs, rather then having them hardwired to the correct
> +	 * values as is normally done.
> +	 *
> +	 * The bq25890_charger driver controls these through I2C, but this only
> +	 * works if not overridden by the pins. Set these pins here:
> +	 * 1. Set /CE to 0 to allow charging.

If I read this correctly then the /CE is an active low pin and setting to 0
means active state which...

> +	 * 2. Set OTG to 0 disable V5 boost output since the 5V boost output of
> +	 *    the main "bq25892_1" charger is used when necessary.
> +	 */
> +
> +	/* /CE pin */
> +	ret = x86_android_tablet_get_gpiod("INT33FF:02", 22, &gpiod);
> +	if (ret < 0)
> +		return ret;

> +	gpiod_set_value(gpiod, 0);

...contradicts with the virtual state here. Perhaps you missed the
corresponding flag to enable negation?

> +	/* OTG pin */
> +	ret = x86_android_tablet_get_gpiod("INT33FF:03", 19, &gpiod);
> +	if (ret < 0)
> +		return ret;
> +
> +	gpiod_set_value(gpiod, 0);

-- 
With Best Regards,
Andy Shevchenko





[Index of Archives]     [Linux Kernel Development]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux