diff options
author | Dave Airlie <airlied@redhat.com> | 2009-09-01 01:25:57 -0400 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2009-09-07 18:54:31 -0400 |
commit | 551ebd837c75fc75df81811a18b7136c39cab487 (patch) | |
tree | 9703fd46cf9ad170012754f984375db37d2bf818 /drivers/gpu/drm/radeon/radeon_reg.h | |
parent | 11670d3c93210793562748d83502ecbef4034765 (diff) |
drm/radeon/kms: add rn50/r100/r200 CS tracker.
This adds the command stream checker for the RN50, R100 and R200 cards.
It stops any access to 3D registers on RN50, and does checks
on buffer sizes on the r100/r200 cards. It also fixes some texture
sizing checks on r300.
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/radeon/radeon_reg.h')
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_reg.h | 57 |
1 files changed, 56 insertions, 1 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_reg.h b/drivers/gpu/drm/radeon/radeon_reg.h index 4df43f62c678..404b39bf3430 100644 --- a/drivers/gpu/drm/radeon/radeon_reg.h +++ b/drivers/gpu/drm/radeon/radeon_reg.h | |||
@@ -1945,6 +1945,11 @@ | |||
1945 | # define RADEON_TXFORMAT_DXT1 (12 << 0) | 1945 | # define RADEON_TXFORMAT_DXT1 (12 << 0) |
1946 | # define RADEON_TXFORMAT_DXT23 (14 << 0) | 1946 | # define RADEON_TXFORMAT_DXT23 (14 << 0) |
1947 | # define RADEON_TXFORMAT_DXT45 (15 << 0) | 1947 | # define RADEON_TXFORMAT_DXT45 (15 << 0) |
1948 | # define RADEON_TXFORMAT_SHADOW16 (16 << 0) | ||
1949 | # define RADEON_TXFORMAT_SHADOW32 (17 << 0) | ||
1950 | # define RADEON_TXFORMAT_DUDV88 (18 << 0) | ||
1951 | # define RADEON_TXFORMAT_LDUDV655 (19 << 0) | ||
1952 | # define RADEON_TXFORMAT_LDUDUV8888 (20 << 0) | ||
1948 | # define RADEON_TXFORMAT_FORMAT_MASK (31 << 0) | 1953 | # define RADEON_TXFORMAT_FORMAT_MASK (31 << 0) |
1949 | # define RADEON_TXFORMAT_FORMAT_SHIFT 0 | 1954 | # define RADEON_TXFORMAT_FORMAT_SHIFT 0 |
1950 | # define RADEON_TXFORMAT_APPLE_YUV_MODE (1 << 5) | 1955 | # define RADEON_TXFORMAT_APPLE_YUV_MODE (1 << 5) |
@@ -2203,7 +2208,7 @@ | |||
2203 | # define RADEON_ROP_ENABLE (1 << 6) | 2208 | # define RADEON_ROP_ENABLE (1 << 6) |
2204 | # define RADEON_STENCIL_ENABLE (1 << 7) | 2209 | # define RADEON_STENCIL_ENABLE (1 << 7) |
2205 | # define RADEON_Z_ENABLE (1 << 8) | 2210 | # define RADEON_Z_ENABLE (1 << 8) |
2206 | # define RADEON_DEPTH_XZ_OFFEST_ENABLE (1 << 9) | 2211 | # define RADEON_DEPTHXY_OFFSET_ENABLE (1 << 9) |
2207 | # define RADEON_RB3D_COLOR_FORMAT_SHIFT 10 | 2212 | # define RADEON_RB3D_COLOR_FORMAT_SHIFT 10 |
2208 | 2213 | ||
2209 | # define RADEON_COLOR_FORMAT_ARGB1555 3 | 2214 | # define RADEON_COLOR_FORMAT_ARGB1555 3 |
@@ -2773,7 +2778,12 @@ | |||
2773 | # define R200_TXFORMAT_DXT1 (12 << 0) | 2778 | # define R200_TXFORMAT_DXT1 (12 << 0) |
2774 | # define R200_TXFORMAT_DXT23 (14 << 0) | 2779 | # define R200_TXFORMAT_DXT23 (14 << 0) |
2775 | # define R200_TXFORMAT_DXT45 (15 << 0) | 2780 | # define R200_TXFORMAT_DXT45 (15 << 0) |
2781 | # define R200_TXFORMAT_DVDU88 (18 << 0) | ||
2782 | # define R200_TXFORMAT_LDVDU655 (19 << 0) | ||
2783 | # define R200_TXFORMAT_LDVDU8888 (20 << 0) | ||
2784 | # define R200_TXFORMAT_GR1616 (21 << 0) | ||
2776 | # define R200_TXFORMAT_ABGR8888 (22 << 0) | 2785 | # define R200_TXFORMAT_ABGR8888 (22 << 0) |
2786 | # define R200_TXFORMAT_BGR111110 (23 << 0) | ||
2777 | # define R200_TXFORMAT_FORMAT_MASK (31 << 0) | 2787 | # define R200_TXFORMAT_FORMAT_MASK (31 << 0) |
2778 | # define R200_TXFORMAT_FORMAT_SHIFT 0 | 2788 | # define R200_TXFORMAT_FORMAT_SHIFT 0 |
2779 | # define R200_TXFORMAT_ALPHA_IN_MAP (1 << 6) | 2789 | # define R200_TXFORMAT_ALPHA_IN_MAP (1 << 6) |
@@ -2818,6 +2828,13 @@ | |||
2818 | #define R200_PP_TXPITCH_4 0x2c90 /* NPOT only */ | 2828 | #define R200_PP_TXPITCH_4 0x2c90 /* NPOT only */ |
2819 | #define R200_PP_TXPITCH_5 0x2cb0 /* NPOT only */ | 2829 | #define R200_PP_TXPITCH_5 0x2cb0 /* NPOT only */ |
2820 | 2830 | ||
2831 | #define R200_PP_CUBIC_FACES_0 0x2c18 | ||
2832 | #define R200_PP_CUBIC_FACES_1 0x2c38 | ||
2833 | #define R200_PP_CUBIC_FACES_2 0x2c58 | ||
2834 | #define R200_PP_CUBIC_FACES_3 0x2c78 | ||
2835 | #define R200_PP_CUBIC_FACES_4 0x2c98 | ||
2836 | #define R200_PP_CUBIC_FACES_5 0x2cb8 | ||
2837 | |||
2821 | #define R200_PP_TXOFFSET_0 0x2d00 | 2838 | #define R200_PP_TXOFFSET_0 0x2d00 |
2822 | # define R200_TXO_ENDIAN_NO_SWAP (0 << 0) | 2839 | # define R200_TXO_ENDIAN_NO_SWAP (0 << 0) |
2823 | # define R200_TXO_ENDIAN_BYTE_SWAP (1 << 0) | 2840 | # define R200_TXO_ENDIAN_BYTE_SWAP (1 << 0) |
@@ -2829,11 +2846,44 @@ | |||
2829 | # define R200_TXO_MICRO_TILE (1 << 3) | 2846 | # define R200_TXO_MICRO_TILE (1 << 3) |
2830 | # define R200_TXO_OFFSET_MASK 0xffffffe0 | 2847 | # define R200_TXO_OFFSET_MASK 0xffffffe0 |
2831 | # define R200_TXO_OFFSET_SHIFT 5 | 2848 | # define R200_TXO_OFFSET_SHIFT 5 |
2849 | #define R200_PP_CUBIC_OFFSET_F1_0 0x2d04 | ||
2850 | #define R200_PP_CUBIC_OFFSET_F2_0 0x2d08 | ||
2851 | #define R200_PP_CUBIC_OFFSET_F3_0 0x2d0c | ||
2852 | #define R200_PP_CUBIC_OFFSET_F4_0 0x2d10 | ||
2853 | #define R200_PP_CUBIC_OFFSET_F5_0 0x2d14 | ||
2854 | |||
2832 | #define R200_PP_TXOFFSET_1 0x2d18 | 2855 | #define R200_PP_TXOFFSET_1 0x2d18 |
2856 | #define R200_PP_CUBIC_OFFSET_F1_1 0x2d1c | ||
2857 | #define R200_PP_CUBIC_OFFSET_F2_1 0x2d20 | ||
2858 | #define R200_PP_CUBIC_OFFSET_F3_1 0x2d24 | ||
2859 | #define R200_PP_CUBIC_OFFSET_F4_1 0x2d28 | ||
2860 | #define R200_PP_CUBIC_OFFSET_F5_1 0x2d2c | ||
2861 | |||
2833 | #define R200_PP_TXOFFSET_2 0x2d30 | 2862 | #define R200_PP_TXOFFSET_2 0x2d30 |
2863 | #define R200_PP_CUBIC_OFFSET_F1_2 0x2d34 | ||
2864 | #define R200_PP_CUBIC_OFFSET_F2_2 0x2d38 | ||
2865 | #define R200_PP_CUBIC_OFFSET_F3_2 0x2d3c | ||
2866 | #define R200_PP_CUBIC_OFFSET_F4_2 0x2d40 | ||
2867 | #define R200_PP_CUBIC_OFFSET_F5_2 0x2d44 | ||
2868 | |||
2834 | #define R200_PP_TXOFFSET_3 0x2d48 | 2869 | #define R200_PP_TXOFFSET_3 0x2d48 |
2870 | #define R200_PP_CUBIC_OFFSET_F1_3 0x2d4c | ||
2871 | #define R200_PP_CUBIC_OFFSET_F2_3 0x2d50 | ||
2872 | #define R200_PP_CUBIC_OFFSET_F3_3 0x2d54 | ||
2873 | #define R200_PP_CUBIC_OFFSET_F4_3 0x2d58 | ||
2874 | #define R200_PP_CUBIC_OFFSET_F5_3 0x2d5c | ||
2835 | #define R200_PP_TXOFFSET_4 0x2d60 | 2875 | #define R200_PP_TXOFFSET_4 0x2d60 |
2876 | #define R200_PP_CUBIC_OFFSET_F1_4 0x2d64 | ||
2877 | #define R200_PP_CUBIC_OFFSET_F2_4 0x2d68 | ||
2878 | #define R200_PP_CUBIC_OFFSET_F3_4 0x2d6c | ||
2879 | #define R200_PP_CUBIC_OFFSET_F4_4 0x2d70 | ||
2880 | #define R200_PP_CUBIC_OFFSET_F5_4 0x2d74 | ||
2836 | #define R200_PP_TXOFFSET_5 0x2d78 | 2881 | #define R200_PP_TXOFFSET_5 0x2d78 |
2882 | #define R200_PP_CUBIC_OFFSET_F1_5 0x2d7c | ||
2883 | #define R200_PP_CUBIC_OFFSET_F2_5 0x2d80 | ||
2884 | #define R200_PP_CUBIC_OFFSET_F3_5 0x2d84 | ||
2885 | #define R200_PP_CUBIC_OFFSET_F4_5 0x2d88 | ||
2886 | #define R200_PP_CUBIC_OFFSET_F5_5 0x2d8c | ||
2837 | 2887 | ||
2838 | #define R200_PP_TFACTOR_0 0x2ee0 | 2888 | #define R200_PP_TFACTOR_0 0x2ee0 |
2839 | #define R200_PP_TFACTOR_1 0x2ee4 | 2889 | #define R200_PP_TFACTOR_1 0x2ee4 |
@@ -3175,6 +3225,11 @@ | |||
3175 | # define R200_FORCE_INORDER_PROC (1<<31) | 3225 | # define R200_FORCE_INORDER_PROC (1<<31) |
3176 | #define R200_PP_CNTL_X 0x2cc4 | 3226 | #define R200_PP_CNTL_X 0x2cc4 |
3177 | #define R200_PP_TXMULTI_CTL_0 0x2c1c | 3227 | #define R200_PP_TXMULTI_CTL_0 0x2c1c |
3228 | #define R200_PP_TXMULTI_CTL_1 0x2c3c | ||
3229 | #define R200_PP_TXMULTI_CTL_2 0x2c5c | ||
3230 | #define R200_PP_TXMULTI_CTL_3 0x2c7c | ||
3231 | #define R200_PP_TXMULTI_CTL_4 0x2c9c | ||
3232 | #define R200_PP_TXMULTI_CTL_5 0x2cbc | ||
3178 | #define R200_SE_VTX_STATE_CNTL 0x2180 | 3233 | #define R200_SE_VTX_STATE_CNTL 0x2180 |
3179 | # define R200_UPDATE_USER_COLOR_0_ENA_MASK (1<<16) | 3234 | # define R200_UPDATE_USER_COLOR_0_ENA_MASK (1<<16) |
3180 | 3235 | ||