diff --git a/paddle/fluid/operators/range_op_xpu.cc b/paddle/fluid/operators/range_op_xpu.cc index f37a8b34a0fd64dadbb96572b4d0691c73e87b01..b450ece452816881db73e8d092ab19191dacfb6e 100644 --- a/paddle/fluid/operators/range_op_xpu.cc +++ b/paddle/fluid/operators/range_op_xpu.cc @@ -29,11 +29,11 @@ class XPURangeKernel : public framework::OpKernel { auto* out = context.Output("Out"); framework::Tensor n; - framework::TensorCopy(*start_t, platform::CPUPlace(), &n); + framework::TensorCopySync(*start_t, platform::CPUPlace(), &n); T start = n.data()[0]; - framework::TensorCopy(*end_t, platform::CPUPlace(), &n); + framework::TensorCopySync(*end_t, platform::CPUPlace(), &n); T end = n.data()[0]; - framework::TensorCopy(*step_t, platform::CPUPlace(), &n); + framework::TensorCopySync(*step_t, platform::CPUPlace(), &n); T step = n.data()[0]; int64_t size = 0; diff --git a/python/paddle/device.py b/python/paddle/device.py index 2beb92f2c3a75f52fe29ce2408433efec0354bd9..81b1dfcc745a4adadc68e3391c4b07a0d6cb4b0a 100644 --- a/python/paddle/device.py +++ b/python/paddle/device.py @@ -14,7 +14,7 @@ # TODO: define the functions to manipulate devices import re - +import os from paddle.fluid import core from paddle.fluid import framework from paddle.fluid.dygraph.parallel import ParallelEnv @@ -137,7 +137,9 @@ def set_device(device): raise ValueError( "The device should not be 'xpu', " \ "since PaddlePaddle is not compiled with XPU") - place = core.XPUPlace(ParallelEnv().dev_id) + selected_xpus = os.getenv("FLAGS_selected_xpus", "0").split(",") + device_id = int(selected_xpus[0]) + place = core.XPUPlace(device_id) else: avaliable_gpu_device = re.match(r'gpu:\d+', lower_device) avaliable_xpu_device = re.match(r'xpu:\d+', lower_device)