mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2025-12-21 05:00:09 +01:00
Add basic KHR_8bit_storage support for Adreno 750 devices, for now enabling the storageBuffer8BitAccess feature. A separate descriptor is provided for 8-bit storage access. The descriptor index is adjusted appropriately for 8-bit SSBO loads and stores. The 8-bit SSBO loads cannot go through isam since that instruction isn't able to handle those. The ldib and stib instruction encodings are a bit peculiar but they match the blob's image buffer access through VK_FORMAT_R8 and the dedicated descriptor. These loads and stores do not work in vectorized form, so they have to be scalarized. Additionally stores of 8-bit values have to clear up higher bits of those values. 8-bit truncation can leave higher bits as undefined. Zero-extension of 8-bit values has to use masking since the corresponding cov instruction doesn't function as intended. 8-bit sign extension through cov from a non-shared to a shared register also doesn't work, so an exception is applied to avoid it. Conversion of 8-bit values to and from floating-point values also doesn't work with a straightforward cov instruction, instead the conversion has to go through a 16-bit value. Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/9979 Signed-off-by: Zan Dobersek <zdobersek@igalia.com> Reviewed-by: Connor Abbott <cwabbott0@gmail.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/28254> |
||
|---|---|---|
| .. | ||
| _extra | ||
| _exts | ||
| ci | ||
| drivers | ||
| gallium | ||
| header-stubs | ||
| isl | ||
| mesa3d_theme | ||
| nir | ||
| relnotes | ||
| vulkan | ||
| amber.rst | ||
| android.rst | ||
| application-issues.rst | ||
| ARB_color_buffer_float.txt | ||
| bugs.rst | ||
| codingstyle.rst | ||
| conf.py | ||
| conform.rst | ||
| debugging.rst | ||
| devinfo.rst | ||
| dispatch.rst | ||
| download.rst | ||
| egl.rst | ||
| envvars.rst | ||
| extensions.rst | ||
| faq.rst | ||
| favicon.ico | ||
| favicon.svg | ||
| features.txt | ||
| gallium-nine.rst | ||
| gitlab-ci.yml | ||
| gpu-perf-tracing.rst | ||
| gpuvis.rst | ||
| helpwanted.rst | ||
| history.rst | ||
| index.rst | ||
| install.rst | ||
| isaspec.rst | ||
| libGL.txt | ||
| license.rst | ||
| lists.rst | ||
| macos.rst | ||
| meson.build | ||
| meson.rst | ||
| opengles.rst | ||
| osmesa.rst | ||
| perf.rst | ||
| perfetto.rst | ||
| precompiled.rst | ||
| README.UVD | ||
| README.VCE | ||
| release-calendar.csv | ||
| release-calendar.rst | ||
| release-maintainers-keys.asc | ||
| releasing.rst | ||
| relnotes.rst | ||
| repository.rst | ||
| rusticl.rst | ||
| shading.rst | ||
| sourcetree.rst | ||
| submittingpatches.rst | ||
| systems.rst | ||
| teflon.rst | ||
| u_trace.rst | ||
| utilities.rst | ||
| viewperf.rst | ||
| xlibdriver.rst | ||
The software may implement third party technologies (e.g. third party libraries) that are not licensed to you by AMD and for which you may need to obtain licenses from other parties. Unless explicitly stated otherwise, these third party technologies are not licensed hereunder. Such third party technologies include, but are not limited, to H.264, MPEG-2, MPEG-4, AVC, and VC-1. For MPEG-2 Intermediate Products: ANY USE OF THIS PRODUCT IN ANY MANNER OTHER THAN PERSONAL USE THAT COMPLIES WITH THE MPEG-2 STANDARD IS EXPRESSLY PROHIBITED WITHOUT A LICENSE UNDER APPLICABLE PATENTS IN THE MPEG-2 PATENT PORTFOLIO, WHICH LICENSES IS AVAILABLE FROM MPEG LA, LLC, 6312 S. Fiddlers Green Circle, Suite 400E, Greenwood Village, Colorado 80111 U.S.A. WARRANTY DISCLAIMER: THE SOFTWARE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. AMD DISCLAIMS ALL WARRANTIES, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE, NON-INFRINGEMENT, THAT THE SOFTWARE WILL RUN UNINTERRUPTED OR ERROR-FREE OR WARRANTIES ARISING FROM CUSTOM OF TRADE OR COURSE OF USAGE. THE ENTIRE RISK ASSOCIATED WITH THE USE OF THE SOFTWARE IS ASSUMED BY YOU. Some jurisdictions do not allow the exclusion of implied warranties, so the above exclusion may not apply to You. LIMITATION OF LIABILITY AND INDEMNIFICATION: AMD AND ITS LICENSORS WILL NOT, UNDER ANY CIRCUMSTANCES BE LIABLE FOR ANY PUNITIVE, DIRECT, INCIDENTAL, INDIRECT, SPECIAL OR CONSEQUENTIAL DAMAGES ARISING FROM USE OF THE SOFTWARE OR THIS AGREEMENT EVEN IF AMD AND ITS LICENSORS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. In no event shall AMD's total liability to You for all damages, losses, and causes of action (whether in contract, tort (including negligence) or otherwise) exceed the amount of $100 USD. You agree to defend, indemnify and hold harmless AMD and its licensors, and any of their directors, officers, employees, affiliates or agents from and against any and all loss, damage, liability and other expenses (including reasonable attorneys' fees), resulting from Your use of the Software or violation of the terms and conditions of this Agreement. U.S. GOVERNMENT RESTRICTED RIGHTS: The Software is provided with "RESTRICTED RIGHTS." Use, duplication, or disclosure by the Government is subject to the restrictions as set forth in FAR 52.227-14 and DFAR252.227-7013, et seq., or its successor. Use of the Software by the Government constitutes acknowledgement of AMD's proprietary rights in them. EXPORT RESTRICTIONS: The Software may be subject to export restrictions as stated in the Software License Agreement.