Skip to content

Commit

Permalink
Fix nprocs description for xmp.spawn; error if nprocs != 1 or None (#…
Browse files Browse the repository at this point in the history
  • Loading branch information
jeffhataws authored Sep 25, 2024
1 parent b378a28 commit 3cd4677
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 3 deletions.
8 changes: 6 additions & 2 deletions torch_xla/_internal/pjrt.py
Original file line number Diff line number Diff line change
Expand Up @@ -194,7 +194,9 @@ def spawn(fn: Callable,
Args:
fn: Callable that takes the process index as the first argument.
nprocs (int): The number of processes/devices for the replication. At the
moment, if specified, can be either 1 or the maximum number of devices.
moment, if specified, can be either 1 or None (which would automatically
converted to the maximum number of devices). Other numbers would result
in ValueError.
args: args to pass to `fn`
start_method: The Python `multiprocessing` process creation method.
Default: `spawn`
Expand All @@ -204,7 +206,9 @@ def spawn(fn: Callable,
if nprocs == 1:
return _run_singleprocess(spawn_fn)
elif nprocs is not None:
logging.warning('Unsupported nprocs (%d), ignoring...' % nprocs)
raise ValueError(
'Unsupported nprocs (%d). Please use the environment variable for the hardware you are using (X_NUM_DEVICES where X is CPU, GPU, TPU, NEURONCORE, etc).'
% nprocs)

run_multiprocess(spawn_fn, start_method=start_method)

Expand Down
4 changes: 3 additions & 1 deletion torch_xla/distributed/xla_multiprocessing.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,9 @@ def spawn(fn,
args (tuple): The arguments for `fn`.
Default: Empty tuple
nprocs (int): The number of processes/devices for the replication. At the
moment, if specified, can be either 1 or the maximum number of devices.
moment, if specified, can be either 1 or None (which would automatically
converted to the maximum number of devices). Other numbers would result
in ValueError.
join (bool): Whether the call should block waiting for the completion of the
processes which have being spawned.
Default: True
Expand Down

0 comments on commit 3cd4677

Please sign in to comment.