| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163 |
- # copyright (c) 2024 PaddlePaddle Authors. All Rights Reserve.
- #
- # Licensed under the Apache License, Version 2.0 (the "License");
- # you may not use this file except in compliance with the License.
- # You may obtain a copy of the License at
- #
- # http://www.apache.org/licenses/LICENSE-2.0
- #
- # Unless required by applicable law or agreed to in writing, software
- # distributed under the License is distributed on an "AS IS" BASIS,
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- # See the License for the specific language governing permissions and
- # limitations under the License.
- import os
- import GPUtil
- import lazy_paddle as paddle
- from . import logging
- from .flags import DISABLE_DEV_MODEL_WL
- from .errors import raise_unsupported_device_error
- from .custom_device_whitelist import (
- DCU_WHITELIST,
- MLU_WHITELIST,
- NPU_WHITELIST,
- XPU_WHITELIST,
- GCU_WHITELIST,
- )
- SUPPORTED_DEVICE_TYPE = ["cpu", "gpu", "xpu", "npu", "mlu", "gcu", "dcu"]
- def constr_device(device_type, device_ids):
- if device_type == "cpu" and device_ids is not None:
- raise ValueError("`device_ids` must be None for CPUs")
- if device_ids:
- device_ids = ",".join(map(str, device_ids))
- return f"{device_type}:{device_ids}"
- else:
- return f"{device_type}"
- def get_default_device():
- avail_gpus = GPUtil.getAvailable()
- if not avail_gpus:
- # maybe edge devices like Jetson
- if os.path.exists("/etc/nv_tegra_release"):
- avail_gpus = [0]
- logging.info(
- "Detected that the current device is a Jetson edge device. The default behavior will be to use GPU: 0"
- )
- if not avail_gpus:
- return "cpu"
- else:
- return constr_device("gpu", [avail_gpus[0]])
- def parse_device(device):
- """parse_device"""
- # According to https://www.paddlepaddle.org.cn/documentation/docs/zh/api/paddle/device/set_device_cn.html
- parts = device.split(":")
- if len(parts) > 2:
- raise ValueError(f"Invalid device: {device}")
- if len(parts) == 1:
- device_type, device_ids = parts[0], None
- else:
- device_type, device_ids = parts
- device_ids = device_ids.split(",")
- for device_id in device_ids:
- if not device_id.isdigit():
- raise ValueError(
- f"Device ID must be an integer. Invalid device ID: {device_id}"
- )
- device_ids = list(map(int, device_ids))
- device_type = device_type.lower()
- # raise_unsupported_device_error(device_type, SUPPORTED_DEVICE_TYPE)
- assert device_type.lower() in SUPPORTED_DEVICE_TYPE
- if device_type == "cpu" and device_ids is not None:
- raise ValueError("No Device ID should be specified for CPUs")
- return device_type, device_ids
- def update_device_num(device, num):
- device_type, device_ids = parse_device(device)
- if device_ids:
- assert len(device_ids) >= num
- return constr_device(device_type, device_ids[:num])
- else:
- return constr_device(device_type, device_ids)
- def set_env_for_device(device):
- device_type, _ = parse_device(device)
- return set_env_for_device_type(device_type)
- def set_env_for_device_type(device_type):
- def _set(envs):
- for key, val in envs.items():
- os.environ[key] = val
- logging.debug(f"{key} has been set to {val}.")
- # XXX: is_compiled_with_rocm() must be True on dcu platform ?
- if device_type.lower() == "dcu" and paddle.is_compiled_with_rocm():
- envs = {"FLAGS_conv_workspace_size_limit": "2000"}
- _set(envs)
- if device_type.lower() == "npu":
- envs = {
- "FLAGS_npu_jit_compile": "0",
- "FLAGS_use_stride_kernel": "0",
- "FLAGS_allocator_strategy": "auto_growth",
- "CUSTOM_DEVICE_BLACK_LIST": "pad3d,pad3d_grad,set_value,set_value_with_tensor",
- "FLAGS_npu_scale_aclnn": "True",
- "FLAGS_npu_split_aclnn": "True",
- }
- _set(envs)
- if device_type.lower() == "xpu":
- envs = {
- "BKCL_FORCE_SYNC": "1",
- "BKCL_TIMEOUT": "1800",
- "FLAGS_use_stride_kernel": "0",
- "XPU_BLACK_LIST": "pad3d",
- }
- _set(envs)
- if device_type.lower() == "mlu":
- envs = {"FLAGS_use_stride_kernel": "0"}
- _set(envs)
- if device_type.lower() == "gcu":
- envs = {"FLAGS_use_stride_kernel": "0"}
- _set(envs)
- def check_supported_device_type(device_type, model_name):
- if DISABLE_DEV_MODEL_WL:
- logging.warning(
- "Skip checking if model is supported on device because the flag `PADDLE_PDX_DISABLE_DEV_MODEL_WL` has been set."
- )
- return
- if device_type == "dcu":
- assert (
- model_name in DCU_WHITELIST
- ), f"The DCU device does not yet support `{model_name}` model!"
- elif device_type == "mlu":
- assert (
- model_name in MLU_WHITELIST
- ), f"The MLU device does not yet support `{model_name}` model!"
- elif device_type == "npu":
- assert (
- model_name in NPU_WHITELIST
- ), f"The NPU device does not yet support `{model_name}` model!"
- elif device_type == "xpu":
- assert (
- model_name in XPU_WHITELIST
- ), f"The XPU device does not yet support `{model_name}` model!"
- elif device_type == "gcu":
- assert (
- model_name in GCU_WHITELIST
- ), f"The GCU device does not yet support `{model_name}` model!"
- def check_supported_device(device, model_name):
- device_type, _ = parse_device(device)
- return check_supported_device_type(device_type, model_name)
|