Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4441836pxj; Wed, 12 May 2021 05:53:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyvYbSzDGOflvROqWtek07nhtMXfA+kT1Ihecow7gtW5PPxdQQt74IkZMY9TZDCXaOSLfkV X-Received: by 2002:a05:6402:7d4:: with SMTP id u20mr3812125edy.302.1620823983435; Wed, 12 May 2021 05:53:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620823983; cv=none; d=google.com; s=arc-20160816; b=pasTUAibxdsqC3/yY0KDtq0EgwnFAZmXzk+6PQ7ygFb/0mETXJrWQ4YLHBrdTzkdrF /aJQhW0tkmLrYfNeXh6cy03dTTqE2zXz7Xr+0Hf2qHjoeFzetXzTAROy1NbajntSQTfc U0X421toh1QR9v7MnCVcLADle46XvJi+NOLtHTi9RMCnFDBG9rozOj5tNDro8Ov06m8l Kx/30YW8bvh2QI08WhPHnZ77KpnkrC8/bGlkzpIEEk/6yE5dHJ4RbOh8kjPyuAEzq2kK dKx8ga2++XUMRzBc+WHviMyeS1m189aTcttn7XlhtoLxFf7BGPFvFuKkMxQ213vU58Jl XO6w== 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=JwxCrwf+H6hdHNunVT7CSuwKVEp6BPAqjULiUAqpmAU=; b=wGfwsRiYPybD9iqdbIDeBPz02La9IN5q1EpwYykGoiSK0sA4urIDwJg/89JlnCYiCZ QnBQqfL6ufcYuww0RWdQSu1tY8+maU2pJaTkvqpzhF6tCOdRnZnD4TsIa8pQyLLNYyhb VbtpklLnhaP60p2cM7FJg+Y27/RdystiPT+767p/E7YkxJNwK+6UQo/31U5eEaFW93Oj ksoOnSJ9TgWOJvmWdEN/Q2oP4m/RUAJea2gVvy+5FKSuJTvz+hG7cvVdPPPRam5H/UK2 /l7h9YqQtJbxcPespVv/k9FewPL3BE+kxTbs+qn4+1BCv2scTwnPL4lEIiDHcUqGQ2FO npmw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=izWxN+DP; 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 g3si3013437edr.171.2021.05.12.05.52.16; Wed, 12 May 2021 05:53:03 -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=izWxN+DP; 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 S232495AbhELMfP (ORCPT + 99 others); Wed, 12 May 2021 08:35:15 -0400 Received: from mail.kernel.org ([198.145.29.99]:56056 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232486AbhELMfO (ORCPT ); Wed, 12 May 2021 08:35:14 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 03B6761041; Wed, 12 May 2021 12:34:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1620822846; bh=X8/54ommkyt5Go8X5+Hbcai9kTbma//sxP0eeZHH9Y4=; h=From:To:Cc:Subject:Date:From; b=izWxN+DPeGXYA+WjUt7F+MRI/ifjvWJNi0kifRDQpFZ2uL7iqGN+u8AiOhr0qGpLd OHRhsurkYh/6pGrTjaR4/BE0ssTkAWS1IIpRPg17rKVGf/bW3Ml0uzGbp+vUG6TPCm UzV4tDfi7Fx3LT7yzpzc5zerW2jS8ALCe+eMweTfDBFBj3PEhq7MCIamWzeC3Ym+jT wvlAuzpplWD18jsS52u4g95rngN3AMvzvJpfqswP7JczyoZ2Mu9atwX4hcoRq4zOu3 9satxjZIDpmoR7jkJlqb3UO25bnkFOonsXL7J5l6uLHBly7B40eNS50jm9K97gG1tF XQkrCrtdlIoCA== From: Mark Brown To: Willy Tarreau Cc: linux-kernel@vger.kernel.org, Mark Brown Subject: [PATCH v3] tools/nolibc: Implement msleep() Date: Wed, 12 May 2021 13:32:15 +0100 Message-Id: <20210512123215.42321-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=Uq9qwA09rFw9e6qEJ6WyyeNvYSBC/dhgo3azkyzvnSk=; g=e3987dff811e06d2d493f10034fbb8ea59bf6b54 X-Patch-Sig: m=pgp; i=broonie@kernel.org; s=0xC3F436CA30F5D8EB; b=iQEzBAABCgAdFiEEreZoqmdXGLWf4p/qJNaLcl1Uh9AFAmCbyKMACgkQJNaLcl1Uh9AmaQf+Jyb p6eNIv2My43VvhLuaHv2Tmn2YF6niS1fMW5y1HbkjBD4CXtVFnJm4Q2hLMaUcBUlJ+QMQEGRJ8l+4 HtAYBOEIIRwHxOMp+hFWTZWtdZnXLTBQr5YWGQEaxug1NeUJGSloB+oFF+kMsl1SX6i3j18XoE23I SSxVX1E9ELWfckjHputFGuvMXXeTnZHOyh0FiMiySEpoRhxj4AGD9gkExmca5WEJws29XK24OOURZ IcBXoUGtMgWQonBkhB94AA5aaaJ5hXm+O/T+oJqi4d6wzoAWOhf5D5UxJXdo54NaP5BeIyGPUiB9f k4u29hmUMltyIHVaNdmbRf0nS689Dfw== 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 --- v3: - Return the number of milliseconds remaining if the delay does not complete. 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 | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/tools/include/nolibc/nolibc.h b/tools/include/nolibc/nolibc.h index 8b7a9830dd22..ba6b6f1ad846 100644 --- a/tools/include/nolibc/nolibc.h +++ b/tools/include/nolibc/nolibc.h @@ -2243,6 +2243,19 @@ 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 * 1000) + + (my_timeval.tv_usec / 1000) + + !!(my_timeval.tv_usec % 1000); + else + return 0; +} + static __attribute__((unused)) int stat(const char *path, struct stat *buf) { -- 2.20.1