On Mon, 2016-08-29 at 20:13 +0200, Vedran Miletić wrote: > Clover presently reports 32 as CL_DEVICE_ADDRESS_BITS, which is not > correct for AMD SI and newer chip generations. This patch introduces > the PIPE_COMPUTE_CAP_ADDRESS_BITS pipe capability queried by Clover > to r600 pipe and sets the value to 32 for AMD EG/NI chips and 64 for > SI and newer (chips older than EG will not use this capability).
I pushed my version that handles the PIPE_CAP in other pipes as well. Jan > > Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=97513 > Signed-off-by: Vedran Miletić <ved...@miletic.net> > --- > src/gallium/drivers/radeon/r600_pipe_common.c | 9 +++++++++ > src/gallium/include/pipe/p_defines.h | 3 ++- > src/gallium/state_trackers/clover/api/device.cpp | 2 +- > src/gallium/state_trackers/clover/core/device.cpp | 6 ++++++ > src/gallium/state_trackers/clover/core/device.hpp | 1 + > 5 files changed, 19 insertions(+), 2 deletions(-) > > diff --git a/src/gallium/drivers/radeon/r600_pipe_common.c > b/src/gallium/drivers/radeon/r600_pipe_common.c > index b1da22f..7385715 100644 > --- a/src/gallium/drivers/radeon/r600_pipe_common.c > +++ b/src/gallium/drivers/radeon/r600_pipe_common.c > @@ -955,6 +955,15 @@ static int r600_get_compute_param(struct > pipe_screen *screen, > *subgroup_size = > r600_wavefront_size(rscreen->family); > } > return sizeof(uint32_t); > + case PIPE_COMPUTE_CAP_ADDRESS_BITS: > + if (ret) { > + uint32_t *address_bits = ret; > + if (rscreen->chip_class >= SI) > + *address_bits = 64; > + else > + *address_bits = 32; > + } > + return sizeof(uint32_t); > } > > fprintf(stderr, "unknown PIPE_COMPUTE_CAP %d\n", param); > diff --git a/src/gallium/include/pipe/p_defines.h > b/src/gallium/include/pipe/p_defines.h > index 1e4d802..93e30e8 100644 > --- a/src/gallium/include/pipe/p_defines.h > +++ b/src/gallium/include/pipe/p_defines.h > @@ -847,7 +847,8 @@ enum pipe_compute_cap > PIPE_COMPUTE_CAP_MAX_CLOCK_FREQUENCY, > PIPE_COMPUTE_CAP_MAX_COMPUTE_UNITS, > PIPE_COMPUTE_CAP_IMAGES_SUPPORTED, > - PIPE_COMPUTE_CAP_SUBGROUP_SIZE > + PIPE_COMPUTE_CAP_SUBGROUP_SIZE, > + PIPE_COMPUTE_CAP_ADDRESS_BITS > }; > > /** > diff --git a/src/gallium/state_trackers/clover/api/device.cpp > b/src/gallium/state_trackers/clover/api/device.cpp > index 11f21e9..f7bd61b 100644 > --- a/src/gallium/state_trackers/clover/api/device.cpp > +++ b/src/gallium/state_trackers/clover/api/device.cpp > @@ -158,7 +158,7 @@ clGetDeviceInfo(cl_device_id d_dev, > cl_device_info param, > break; > > case CL_DEVICE_ADDRESS_BITS: > - buf.as_scalar<cl_uint>() = 32; > + buf.as_scalar<cl_uint>() = dev.address_bits(); > break; > > case CL_DEVICE_MAX_READ_IMAGE_ARGS: > diff --git a/src/gallium/state_trackers/clover/core/device.cpp > b/src/gallium/state_trackers/clover/core/device.cpp > index 39f39f4..8825f99 100644 > --- a/src/gallium/state_trackers/clover/core/device.cpp > +++ b/src/gallium/state_trackers/clover/core/device.cpp > @@ -193,6 +193,12 @@ device::subgroup_size() const { > PIPE_COMPUTE_CAP_SUBGROUP_SIZE > )[0]; > } > > +cl_uint > +device::address_bits() const { > + return get_compute_param<uint32_t>(pipe, ir_format(), > + PIPE_COMPUTE_CAP_ADDRESS_BITS) > [0]; > +} > + > std::string > device::device_name() const { > return pipe->get_name(pipe); > diff --git a/src/gallium/state_trackers/clover/core/device.hpp > b/src/gallium/state_trackers/clover/core/device.hpp > index 2857847..6cf6c7f 100644 > --- a/src/gallium/state_trackers/clover/core/device.hpp > +++ b/src/gallium/state_trackers/clover/core/device.hpp > @@ -68,6 +68,7 @@ namespace clover { > > std::vector<size_t> max_block_size() const; > cl_uint subgroup_size() const; > + cl_uint address_bits() const; > std::string device_name() const; > std::string vendor_name() const; > enum pipe_shader_ir ir_format() const; -- Jan Vesely <jan.ves...@rutgers.edu>
signature.asc
Description: This is a digitally signed message part
_______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/mesa-dev