Message ID | 20180307115604.4031-1-m.szyprowski@samsung.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Hi Marek, On Wed, Mar 07, 2018 at 12:56:04PM +0100, Marek Szyprowski wrote: > Executing stmfts_power_on() function lasts over 2 seconds, what I suppose that is because of calibration that is done as part of powering on? > significantly slows down the boot process if driver is compiled in. > Avoid this delay by forcing this driver to be probed asynchronously. I do not have an objection for making the probe asynchronous, but don't you have similar issue on resume? > > Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com> > --- > drivers/input/touchscreen/stmfts.c | 1 + > 1 file changed, 1 insertion(+) > > diff --git a/drivers/input/touchscreen/stmfts.c b/drivers/input/touchscreen/stmfts.c > index 025bae3853cc..964f1f43f9ba 100644 > --- a/drivers/input/touchscreen/stmfts.c > +++ b/drivers/input/touchscreen/stmfts.c > @@ -812,6 +812,7 @@ static struct i2c_driver stmfts_driver = { > .name = STMFTS_DEV_NAME, > .of_match_table = of_match_ptr(stmfts_of_match), > .pm = &stmfts_pm_ops, > + .probe_type = PROBE_PREFER_ASYNCHRONOUS, > }, > .probe = stmfts_probe, > .remove = stmfts_remove, > -- > 2.15.0 > Thanks.
Hi Dmitry, On 2018-03-07 20:34, Dmitry Torokhov wrote: > Hi Marek, > > On Wed, Mar 07, 2018 at 12:56:04PM +0100, Marek Szyprowski wrote: >> Executing stmfts_power_on() function lasts over 2 seconds, what > I suppose that is because of calibration that is done as part of > powering on? Not only calibration. All executed commands takes significant amount of time: STMFTS_MS_CX_TUNING: 0.85s STMFTS_SS_CX_TUNING: 0.70s STMFTS_FULL_FORCE_CALIBRATION: 0.28s >> significantly slows down the boot process if driver is compiled in. >> Avoid this delay by forcing this driver to be probed asynchronously. > I do not have an objection for making the probe asynchronous, but don't > you have similar issue on resume? Right, similar issue will be on driver resume and it won't be that easy to make it asynchronous. Should I change that function to schedule an asynchronous work? >> Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com> >> --- >> drivers/input/touchscreen/stmfts.c | 1 + >> 1 file changed, 1 insertion(+) >> >> diff --git a/drivers/input/touchscreen/stmfts.c b/drivers/input/touchscreen/stmfts.c >> index 025bae3853cc..964f1f43f9ba 100644 >> --- a/drivers/input/touchscreen/stmfts.c >> +++ b/drivers/input/touchscreen/stmfts.c >> @@ -812,6 +812,7 @@ static struct i2c_driver stmfts_driver = { >> .name = STMFTS_DEV_NAME, >> .of_match_table = of_match_ptr(stmfts_of_match), >> .pm = &stmfts_pm_ops, >> + .probe_type = PROBE_PREFER_ASYNCHRONOUS, >> }, >> .probe = stmfts_probe, >> .remove = stmfts_remove, >> -- >> 2.15.0 >> > Thanks. > Best regards
On Thu, Mar 22, 2018 at 03:33:31PM +0100, Marek Szyprowski wrote: > Hi Dmitry, > > On 2018-03-07 20:34, Dmitry Torokhov wrote: > > Hi Marek, > > > > On Wed, Mar 07, 2018 at 12:56:04PM +0100, Marek Szyprowski wrote: > > > Executing stmfts_power_on() function lasts over 2 seconds, what > > I suppose that is because of calibration that is done as part of > > powering on? > > Not only calibration. All executed commands takes significant amount of > time: > STMFTS_MS_CX_TUNING: 0.85s > STMFTS_SS_CX_TUNING: 0.70s > STMFTS_FULL_FORCE_CALIBRATION: 0.28s > > > > significantly slows down the boot process if driver is compiled in. > > > Avoid this delay by forcing this driver to be probed asynchronously. > > I do not have an objection for making the probe asynchronous, but don't > > you have similar issue on resume? > > Right, similar issue will be on driver resume and it won't be that easy > to make it asynchronous. Should I change that function to schedule an > asynchronous work? Hmm, you'd have to sequence suspend and remove callbacks, and it might wreak havoc with logical device state not quite matching the reality... Have you tried adding call to device_enable_async_suspend() from the probe() and see if the overall resume time is reduced? Thanks.
Hi Dmitry On 2018-03-23 19:35, Dmitry Torokhov wrote: > On Thu, Mar 22, 2018 at 03:33:31PM +0100, Marek Szyprowski wrote: >> Hi Dmitry, >> >> On 2018-03-07 20:34, Dmitry Torokhov wrote: >>> Hi Marek, >>> >>> On Wed, Mar 07, 2018 at 12:56:04PM +0100, Marek Szyprowski wrote: >>>> Executing stmfts_power_on() function lasts over 2 seconds, what >>> I suppose that is because of calibration that is done as part of >>> powering on? >> Not only calibration. All executed commands takes significant amount of >> time: >> STMFTS_MS_CX_TUNING: 0.85s >> STMFTS_SS_CX_TUNING: 0.70s >> STMFTS_FULL_FORCE_CALIBRATION: 0.28s >> >>>> significantly slows down the boot process if driver is compiled in. >>>> Avoid this delay by forcing this driver to be probed asynchronously. >>> I do not have an objection for making the probe asynchronous, but don't >>> you have similar issue on resume? >> Right, similar issue will be on driver resume and it won't be that easy >> to make it asynchronous. Should I change that function to schedule an >> asynchronous work? > Hmm, you'd have to sequence suspend and remove callbacks, and it might > wreak havoc with logical device state not quite matching the reality... > > Have you tried adding call to device_enable_async_suspend() from the > probe() and see if the overall resume time is reduced? Right, this help for resume case. I will send v2. Best regards
diff --git a/drivers/input/touchscreen/stmfts.c b/drivers/input/touchscreen/stmfts.c index 025bae3853cc..964f1f43f9ba 100644 --- a/drivers/input/touchscreen/stmfts.c +++ b/drivers/input/touchscreen/stmfts.c @@ -812,6 +812,7 @@ static struct i2c_driver stmfts_driver = { .name = STMFTS_DEV_NAME, .of_match_table = of_match_ptr(stmfts_of_match), .pm = &stmfts_pm_ops, + .probe_type = PROBE_PREFER_ASYNCHRONOUS, }, .probe = stmfts_probe, .remove = stmfts_remove,
Executing stmfts_power_on() function lasts over 2 seconds, what significantly slows down the boot process if driver is compiled in. Avoid this delay by forcing this driver to be probed asynchronously. Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com> --- drivers/input/touchscreen/stmfts.c | 1 + 1 file changed, 1 insertion(+)