根据 SYCL参考
缓冲区可以由主机数据指针初始化。虽然缓冲区存在,但它拥有主机数据,并且在此期间对主机数据指针的直接访问是未定义的。
这对于输出缓冲区是可以理解的。但是只读缓冲区呢?在以下代码片段中,在内核完成之前访问只读缓冲区是未定义的行为吗?
range<1> bufer_size{ 100 };
buffer<int> in_buf(input_buffer, bufer_size);
buffer<int> out_buf(output_buffer, bufer_size);
auto my_device = default_selector{};
queue q{ my_device };
q.submit([&](handler& h) {
auto x = in_buf.get_access<access::mode::read>(h);
auto y = out_buf.get_access<access::mode::write>(h);
h.parallel_for(bufer_size,
[=](id<1> idx) {
y[idx] = 100 * x[idx] + 1;
});
});
// Is it OK to read input_buffer without waiting for queue to complete?
for (int i = 0; i < size; ++i) {
std::cout << input_buffer[i] << ' ';
}