Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756843AbcLAFta (ORCPT ); Thu, 1 Dec 2016 00:49:30 -0500 Received: from smtp6-v.fe.bosch.de ([139.15.237.11]:20147 "EHLO smtp6-v.fe.bosch.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750775AbcLAFt2 (ORCPT ); Thu, 1 Dec 2016 00:49:28 -0500 From: "ZHANG Xu (BST/ESA3.1)" To: Aniroop Mathur , Dmitry Torokhov , "linux-input@vger.kernel.org" , "linux-kernel@vger.kernel.org" CC: Aniroop Mathur , "s.samuel@samsung.com" , "r.mahale@samsung.com" Subject: RE: [PATCH] Input: Change msleep to usleep_range for small msecs Thread-Topic: [PATCH] Input: Change msleep to usleep_range for small msecs Thread-Index: AQHSSZV4XtYR0VupXkSyAW8IOUH0A6Dykd1g Date: Thu, 1 Dec 2016 05:49:19 +0000 Message-ID: <8e9f01a31e7c408e9dbe85a2bd594e45@SGPMBX1019.APAC.bosch.com> References: <1480003383-1716-1-git-send-email-a.mathur@samsung.com> In-Reply-To: Accept-Language: en-US, en-SG Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-ms-exchange-transport-fromentityheader: Hosted x-originating-ip: [10.173.233.8] Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 X-TM-AS-MML: disable X-TM-AS-Product-Ver: IMSS-7.1.0.1679-8.0.0.1202-22732.001 X-TMASE-MatchedRID: xcONGPdDH5p5X0FJZbmEppmug812qIbzQnVGRb78vpAGW3hFnC9N1Yhs IUVuvfY3KN+WEI/rADTTJZ64a93akpLliITNZcSUzNY33yIEF4Z3gvNDlwkK835tRMJpRVgEEXF HklABLo770AwRX7Ss4khfcUWz5a9oTdtgniHdnTlswYo64ufkVa6xL0KIHMvxo3S8kRONhPZZPx FWRZUqLttbphCyEguTif7LZ2wSYmp+ObgWZsNtPWZUc2jtcaSdddAlhLX1ybXlbPAzatNoQskUh KWc+gwPEhR3fbScnAA1jUZ7PgJlVU8M9+aj5+3HFYJUGv4DL3wUCv7A9Z7uMSa7ZcqwFxbxQmZ9 +1UBYL04+SvEdXkeo8st4N9NReb90YRMm/X9bI7il2r2x2PwtVo1rFkFFs1a1iKCm1YLwn7Ob3+ o8TfeDuLzNWBegCW2PZex/kxUIHW3sNbcHjySQUlXctromFFi+gtHj7OwNO14uFxKD13nMcXMu4 7T03305EwBj/3q18V24rXEKXsrjHjV+y7GGlOW Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Transfer-Encoding: 8bit X-MIME-Autoconverted: from base64 to 8bit by mail.home.local id uB15neui030557 Content-Length: 2696 Lines: 79 Hello Aniroop Mathur Thank you for your mail. We have used the usleep_range() function in our new product's driver and the verification result is working. Your patch for bma150 is definitely working for sure. Just one question need your answer. To replace the msleep(2), is usleep_range(2000, 2100) better than usleep_range(2000, 2000) ? Best regards Albert (Xu) ZHANG BST/ESA3.1 -----Original Message----- From: mathur.aniroop@gmail.com [mailto:mathur.aniroop@gmail.com] On Behalf Of Aniroop Mathur Sent: Tuesday, November 29, 2016 12:36 AM To: ZHANG Xu (BST/ESA3.1) ; Dmitry Torokhov ; linux-input@vger.kernel.org; linux-kernel@vger.kernel.org Cc: Aniroop Mathur ; s.samuel@samsung.com; r.mahale@samsung.com; Aniroop Mathur Subject: Re: [PATCH] Input: Change msleep to usleep_range for small msecs Hello Mr. Albert Zhang, I am Aniroop Mathur from Samsung R&D Institute, India. I have submitted one patch as below for review to Linux Open Source. The problem is that we do not have the hardware available with us to test it and we would like to test it before actually applying it. As you are the author of this driver, so I would like to request you if you could help to test this patch or provide us the contact points of individuals who could support to get this patch tested? Thank you! BR, Aniroop Mathur On Thu, Nov 24, 2016 at 9:33 PM, Aniroop Mathur wrote: > msleep(1~20) may not do what the caller intends, and will often sleep longer. > (~20 ms actual sleep for any value given in the 1~20ms range) > This is not the desired behaviour for many cases like device resume time, > device suspend time, device enable time, etc. > Thus, change msleep to usleep_range for precise wakeups. > > Signed-off-by: Aniroop Mathur > --- > drivers/input/misc/bma150.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/drivers/input/misc/bma150.c b/drivers/input/misc/bma150.c > index 2124390..1fa8537 100644 > --- a/drivers/input/misc/bma150.c > +++ b/drivers/input/misc/bma150.c > @@ -207,7 +207,7 @@ static int bma150_set_mode(struct bma150_data *bma150, u8 mode) > return error; > > if (mode == BMA150_MODE_NORMAL) > - msleep(2); > + usleep_range(2000, 2100); > > bma150->mode = mode; > return 0; > @@ -222,7 +222,7 @@ static int bma150_soft_reset(struct bma150_data *bma150) > if (error) > return error; > > - msleep(2); > + usleep_range(2000, 2100); > return 0; > } > > -- > 2.6.2 >