diff options
author | discus0434 <discus0434@gmail.com> | 2022-10-22 11:14:46 +0000 |
---|---|---|
committer | discus0434 <discus0434@gmail.com> | 2022-10-22 11:14:46 +0000 |
commit | dcb45dfecfd0d7f2c268343d8a83fd33c276345b (patch) | |
tree | 001c8ebf9e0c7af692ae1237142206f568ff6903 /modules/devices.py | |
parent | 0e8ca8e7af05be22d7d2c07a47c3c7febe0f0ab6 (diff) | |
parent | 50b5504401e50b6c94eba41b37fe212b2f27b792 (diff) |
Merge branch 'master' of upstream
Diffstat (limited to 'modules/devices.py')
-rw-r--r-- | modules/devices.py | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/modules/devices.py b/modules/devices.py index eb422583..dc1f3cdd 100644 --- a/modules/devices.py +++ b/modules/devices.py @@ -1,7 +1,6 @@ +import sys, os, shlex import contextlib - import torch - from modules import errors # has_mps is only available in nightly pytorch (for now), `getattr` for compatibility @@ -9,10 +8,22 @@ has_mps = getattr(torch, 'has_mps', False) cpu = torch.device("cpu") +def extract_device_id(args, name): + for x in range(len(args)): + if name in args[x]: return args[x+1] + return None def get_optimal_device(): if torch.cuda.is_available(): - return torch.device("cuda") + from modules import shared + + device_id = shared.cmd_opts.device_id + + if device_id is not None: + cuda_device = f"cuda:{device_id}" + return torch.device(cuda_device) + else: + return torch.device("cuda") if has_mps: return torch.device("mps") @@ -34,7 +45,7 @@ def enable_tf32(): errors.run(enable_tf32, "Enabling TF32") -device = device_interrogate = device_gfpgan = device_bsrgan = device_esrgan = device_scunet = device_codeformer = get_optimal_device() +device = device_interrogate = device_gfpgan = device_bsrgan = device_esrgan = device_scunet = device_codeformer = None dtype = torch.float16 dtype_vae = torch.float16 |