Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4394553pxj; Wed, 12 May 2021 04:52:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwQe3MDmm/WQJqunfeo8oVXLncsAfRGoECUoaEZe2pxdJYJrCwW3drrr2D6ngH/iMZ7SWBJ X-Received: by 2002:a50:fc0b:: with SMTP id i11mr43991610edr.259.1620820369170; Wed, 12 May 2021 04:52:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620820369; cv=none; d=google.com; s=arc-20160816; b=lGTqBcacv+uqn6L5VvRjAdZfbu/Vyb/iJZY/iH1KzGauDehOp7Mx6scSwGTEDT5r1P 3Qrc8wGKVbepntHecIFNhU/745nYXUnwZsVy3YC4a3t/mCsEgMWDTipXg1vD9UmGwXoL CTLT5NbedSUJ33UNehvo2Ur4t/Kpd8x0syIezLlTe9CFmRK+F7kLBiwTQW2f/TaANqex xb46qnD/z9V2lOK/b9ZV56BVVeE68YEK/Mn9yc8fCH92sRRA+AHvd3Dn3uBOP5qpw2yY m/LB+vpZ6IUUnCaUTGSoOMeyA2wtG24imWGzcOBCcVum5xc0HEAK8pgn1MNk8iXS/P8m cBEA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=lwZMcjMNYT65h4BGve30fOFf5gpKOleaYzHqkU90wU8=; b=TOqxHPTPAoxRCfIv4f6sikwN7Itisb/X1aHaCSNJpDn5LAEmV4kYsoXgX/vPZw63Pb WXnZjnB8fp9AoDhFlRJlZ63iI5ACaPRqyAQoZ/n+JOaptGj2UXEPeDekGYeh7Mi/6mb7 GdBwSI8M0NxekQ7bVeizDYdzpocQtYZglVs6iMRProewBSgUH4/0KKEvVbQ4hOwk70s/ nWx8bc1+yLK8629raGZ6Wc1V/gmMmprX2BNzKdtBPCOuHi9TPzXlWHZQMM0At53qXMZt TBRs1xBiPlxAS56/SLq6f1/9J+mz4R9xBjKYX1yyIPui1fztWSKIrFUB8A52+ulbEdZ3 iJDQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=JYIBsc2N; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n20si19961024edr.379.2021.05.12.04.52.07; Wed, 12 May 2021 04:52:49 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=JYIBsc2N; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230153AbhELLw0 (ORCPT + 99 others); Wed, 12 May 2021 07:52:26 -0400 Received: from mail.kernel.org ([198.145.29.99]:50138 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230037AbhELLwZ (ORCPT ); Wed, 12 May 2021 07:52:25 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 45D1B61353; Wed, 12 May 2021 11:51:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1620820277; bh=NmRdc9G7JJFHGfkGyc+LaMf36FTOlxulYuSeArk85go=; h=From:To:Cc:Subject:Date:From; b=JYIBsc2N2gJ1wUihhjHXfwwG8zZHwoI9PXbiNLIu75YrNBP9bNmT4SpwMSXsgBVo8 cFmYKz0cXt26BGxcR0PDjK0vRU8Tdgpu5ms+qM2Ogj+i2LJnn+DVmlwUkGSc2zFc0L Q4itev67yHXmhYz96ObZrbmzh4Eyk90c4oUccruWT19cazA00ElmOIEnLV0lAEArU3 p0rZHayfCbWOWfRR8rCkTvmfVzk11SgQ2dPvh76WttUf8gu1Fo4EEKhThfkmonRaJ6 Mw9ust8x4Q70aGu73UtIWzCLyyldxrTVaqgNdJ24uM3R/OZRTq1u90LBUfdqEYcPyQ 66LP3DMfeNYFg== From: Mark Brown To: Willy Tarreau Cc: linux-kernel@vger.kernel.org, Mark Brown Subject: [PATCH v2] tools/nolibc: Implement msleep() Date: Wed, 12 May 2021 12:47:28 +0100 Message-Id: <20210512114728.19015-1-broonie@kernel.org> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 X-Patch-Hashes: v=1; h=sha256; i=WROh5SBSWd//p/Sxtx1sSZhXRJr/pNHGmfIOZDLA1ME=; m=DsG0GUH5Pq7W2vv4GT6Z0e1qoDZBWwgUNihInvr8Y2M=; p=goBe/H9D7gHdYDF1GUG3qnE1yXlI/9UHpsYgIuToVI8=; g=e63813b3d0cd70e8afa36d09389e65a5b1a1a1ec X-Patch-Sig: m=pgp; i=broonie@kernel.org; s=0xC3F436CA30F5D8EB; b=iQEzBAABCgAdFiEEreZoqmdXGLWf4p/qJNaLcl1Uh9AFAmCbv/UACgkQJNaLcl1Uh9Dqowf9E16 qjowmtU0rxTE+BOWEJw8Z8f7PM+10vRWw2SjtvvGdKZ065pLYlqLNuvqBjPlIZyUxCk6E0nROrTEE hCX64nrkOCTzxZvz7faioL8p4VQeKMcgJh9kwO4xSUQzRECEw4FHGyv5f4/rWq50mT9tpP9ZaPR7q ed9CkcXUpaGT1wpLTqYwzNIWRLRJWYIZF6QrZRTBtDW7fwG2oCGBWG7KZbMDmQsKGKw3fxPZ0H1Vd K+naIj84fdFH6OVPOClIxOwrKq9Wob1MHh5wfQ8LbQGoDHnJX+9OD3ke7f9b5o/XqQeD6IERPrL2p cKxgBkcnbiBTJHvuTLgaT2Bvl+OfKsw== Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Allow users to implement shorter delays than a full second by implementing msleep(). Signed-off-by: Mark Brown --- v2: - Support delays of more than a second. - Return the number of seconds remaining if the delay does not complete. tools/include/nolibc/nolibc.h | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/tools/include/nolibc/nolibc.h b/tools/include/nolibc/nolibc.h index 8b7a9830dd22..01400d36ce99 100644 --- a/tools/include/nolibc/nolibc.h +++ b/tools/include/nolibc/nolibc.h @@ -2243,6 +2243,17 @@ unsigned int sleep(unsigned int seconds) return 0; } +static __attribute__((unused)) +int msleep(unsigned int msecs) +{ + struct timeval my_timeval = { msecs / 1000, (msecs % 1000) * 1000 }; + + if (sys_select(0, 0, 0, 0, &my_timeval) < 0) + return my_timeval.tv_sec + !!my_timeval.tv_usec; + else + return 0; +} + static __attribute__((unused)) int stat(const char *path, struct stat *buf) { -- 2.20.1