summaryrefslogtreecommitdiffstats
path: root/src/amd/addrlib/inc
diff options
context:
space:
mode:
authorNicolai Hähnle <[email protected]>2016-10-06 18:55:25 +0200
committerMarek Olšák <[email protected]>2017-03-30 14:44:33 +0200
commit7f160efcde41b52ad78e562316384373dab419e3 (patch)
tree1899e86201ade316e50ae8538f3e9c53262a5906 /src/amd/addrlib/inc
parent047d6daf10f9ca8fc37ad32f00b3bbf926ba9e9d (diff)
amd/addrlib: import gfx9 support
Diffstat (limited to 'src/amd/addrlib/inc')
-rw-r--r--src/amd/addrlib/inc/chip/gfx9/gfx9_gb_reg.h81
1 files changed, 81 insertions, 0 deletions
diff --git a/src/amd/addrlib/inc/chip/gfx9/gfx9_gb_reg.h b/src/amd/addrlib/inc/chip/gfx9/gfx9_gb_reg.h
new file mode 100644
index 00000000000..823710cc189
--- /dev/null
+++ b/src/amd/addrlib/inc/chip/gfx9/gfx9_gb_reg.h
@@ -0,0 +1,81 @@
+#if !defined (__GFX9_GB_REG_H__)
+#define __GFX9_GB_REG_H__
+
+/*
+ * Copyright © 2017 Advanced Micro Devices, Inc.
+ * All Rights Reserved.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining
+ * a copy of this software and associated documentation files (the
+ * "Software"), to deal in the Software without restriction, including
+ * without limitation the rights to use, copy, modify, merge, publish,
+ * distribute, sub license, and/or sell copies of the Software, and to
+ * permit persons to whom the Software is furnished to do so, subject to
+ * the following conditions:
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
+ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+ * NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS, AUTHORS
+ * AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
+ * USE OR OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * The above copyright notice and this permission notice (including the
+ * next paragraph) shall be included in all copies or substantial portions
+ * of the Software.
+ */
+
+//
+// Make sure the necessary endian defines are there.
+//
+#if defined(LITTLEENDIAN_CPU)
+#elif defined(BIGENDIAN_CPU)
+#else
+#error "BIGENDIAN_CPU or LITTLEENDIAN_CPU must be defined"
+#endif
+
+union GB_ADDR_CONFIG {
+ struct {
+#if defined(LITTLEENDIAN_CPU)
+ unsigned int NUM_PIPES : 3;
+ unsigned int PIPE_INTERLEAVE_SIZE : 3;
+ unsigned int MAX_COMPRESSED_FRAGS : 2;
+ unsigned int BANK_INTERLEAVE_SIZE : 3;
+ unsigned int : 1;
+ unsigned int NUM_BANKS : 3;
+ unsigned int : 1;
+ unsigned int SHADER_ENGINE_TILE_SIZE : 3;
+ unsigned int NUM_SHADER_ENGINES : 2;
+ unsigned int NUM_GPUS : 3;
+ unsigned int MULTI_GPU_TILE_SIZE : 2;
+ unsigned int NUM_RB_PER_SE : 2;
+ unsigned int ROW_SIZE : 2;
+ unsigned int NUM_LOWER_PIPES : 1;
+ unsigned int SE_ENABLE : 1;
+#elif defined(BIGENDIAN_CPU)
+ unsigned int SE_ENABLE : 1;
+ unsigned int NUM_LOWER_PIPES : 1;
+ unsigned int ROW_SIZE : 2;
+ unsigned int NUM_RB_PER_SE : 2;
+ unsigned int MULTI_GPU_TILE_SIZE : 2;
+ unsigned int NUM_GPUS : 3;
+ unsigned int NUM_SHADER_ENGINES : 2;
+ unsigned int SHADER_ENGINE_TILE_SIZE : 3;
+ unsigned int : 1;
+ unsigned int NUM_BANKS : 3;
+ unsigned int : 1;
+ unsigned int BANK_INTERLEAVE_SIZE : 3;
+ unsigned int MAX_COMPRESSED_FRAGS : 2;
+ unsigned int PIPE_INTERLEAVE_SIZE : 3;
+ unsigned int NUM_PIPES : 3;
+#endif
+ } bitfields, bits;
+ unsigned int u32All;
+ signed int i32All;
+ float f32All;
+};
+
+#endif
+