Revert "[lit] Use os.cpu_count() to cleanup TODO"

A bot owner contacted me.  I will re-land after confirming that this
doesn't break anyone (since it's low priority).

This reverts commit 9946b169c3.
This commit is contained in:
Julian Lettner 2021-01-25 13:31:27 -08:00
parent 12049d8885
commit db1a7089ea
3 changed files with 26 additions and 17 deletions

View File

@ -23,7 +23,7 @@ def parse_args():
metavar="N", metavar="N",
help="Number of workers used for testing", help="Number of workers used for testing",
type=_positive_int, type=_positive_int,
default=lit.util.usable_core_count()) default=lit.util.detectCPUs())
parser.add_argument("--config-prefix", parser.add_argument("--config-prefix",
dest="configPrefix", dest="configPrefix",
metavar="NAME", metavar="NAME",

View File

@ -110,7 +110,7 @@ class Run(object):
# threads counts toward the current process limit. Try to raise the (soft) # threads counts toward the current process limit. Try to raise the (soft)
# process limit so that tests don't fail due to resource exhaustion. # process limit so that tests don't fail due to resource exhaustion.
def _increase_process_limit(self): def _increase_process_limit(self):
ncpus = lit.util.usable_core_count() ncpus = lit.util.detectCPUs()
desired_limit = self.workers * ncpus * 2 # the 2 is a safety factor desired_limit = self.workers * ncpus * 2 # the 2 is a safety factor
# Importing the resource module will likely fail on Windows. # Importing the resource module will likely fail on Windows.

View File

@ -109,23 +109,32 @@ def to_unicode(s):
return s return s
def usable_core_count(): # TODO(yln): multiprocessing.cpu_count()
"""Return the number of cores the current process can use, if supported. # TODO(python3): len(os.sched_getaffinity(0)) and os.cpu_count()
Otherwise, return the total number of cores (like `os.cpu_count()`). def detectCPUs():
Default to 1 if undetermined. """Detects the number of CPUs on a system.
Cribbed from pp.
""" """
try: # Linux, Unix and MacOS:
n = len(os.sched_getaffinity(0)) if hasattr(os, 'sysconf'):
except AttributeError: if 'SC_NPROCESSORS_ONLN' in os.sysconf_names:
n = os.cpu_count() or 1 # Linux & Unix:
ncpus = os.sysconf('SC_NPROCESSORS_ONLN')
# On Windows, with more than 32 processes, process creation often fails with if isinstance(ncpus, int) and ncpus > 0:
return ncpus
else: # OSX:
return int(subprocess.check_output(['sysctl', '-n', 'hw.ncpu'],
stderr=subprocess.STDOUT))
# Windows:
if 'NUMBER_OF_PROCESSORS' in os.environ:
ncpus = int(os.environ['NUMBER_OF_PROCESSORS'])
if ncpus > 0:
# With more than 32 processes, process creation often fails with
# "Too many open files". FIXME: Check if there's a better fix. # "Too many open files". FIXME: Check if there's a better fix.
if platform.system() == 'Windows': return min(ncpus, 32)
return min(n, 32) return 1 # Default
return n
def mkdir(path): def mkdir(path):