radeon: add some more r100 support to test AGP
authorDave Airlie <airlied@redhat.com>
Sun, 2 Nov 2008 23:23:19 +0000 (09:23 +1000)
committerDave Airlie <airlied@redhat.com>
Sun, 2 Nov 2008 23:23:19 +0000 (09:23 +1000)
shared-core/r300_cmdbuf.c
shared-core/radeon_cs.c

index b15e8928a3c8883b1e7661910e456cb73283fdf8..f39a7afd5b6b8deb3c4cc32170ae2d4c639845b2 100644 (file)
@@ -356,6 +356,9 @@ void r300_init_reg_flags(struct drm_device *dev)
 
                } else {
 
+                       ADD_RANGE(RADEON_SE_COORD_FMT, 1);
+                       ADD_RANGE(RADEON_SE_CNTL_STATUS, 1);
+
                        ADD_RANGE(RADEON_PP_TXFILTER_0, 1);
                        ADD_RANGE(RADEON_PP_TXFORMAT_0, 1);
                        ADD_RANGE(RADEON_PP_TEX_SIZE_0, 1);
index f9147136f9e6e7613a9e8f53a70caacd3e051f21..3e47ad120754699c7a10bab6f022755bc244a791 100644 (file)
@@ -122,7 +122,7 @@ static __inline__ int radeon_cs_relocate_packet0(struct drm_device *dev, struct
        /* this is too strict we may want to expand the length in the future and have
         old kernels ignore it. */ 
        if (packet3_hdr != (RADEON_CP_PACKET3 | RADEON_CP_NOP | (RELOC_SIZE << 16))) {
-               DRM_ERROR("Packet 3 was %x should have been %x\n", packet3_hdr, RADEON_CP_PACKET3 | RADEON_CP_NOP | (RELOC_SIZE << 16));
+               DRM_ERROR("Packet 3 was %x should have been %x: reg is %x\n", packet3_hdr, RADEON_CP_PACKET3 | RADEON_CP_NOP | (RELOC_SIZE << 16), reg);
                return -EINVAL;
        }
        
@@ -195,30 +195,6 @@ static int radeon_cs_relocate_packet3(struct drm_device *dev, struct drm_file *f
        return 0;
 }
 
-static __inline__ int radeon_cs_check_offset(struct drm_device *dev,
-                                            uint32_t reg, uint32_t val)
-{
-       uint32_t offset;
-
-       switch(reg) {
-       case RADEON_DST_PITCH_OFFSET:
-       case RADEON_SRC_PITCH_OFFSET:
-               offset = val & ((1 << 22) - 1);
-               offset <<= 10;
-               break;
-       case R300_RB3D_COLOROFFSET0:
-       case R300_ZB_DEPTHOFFSET:
-               offset = val;
-               break;
-       case R300_TX_OFFSET_0:
-       case R300_TX_OFFSET_0+4:
-               offset = val & 0xffffffe0;
-               break;
-       }
-       
-       return 0;
-}
-
 int radeon_cs_packet0(struct drm_device *dev, struct drm_file *file_priv,
                      uint32_t *packets, uint32_t offset_dw)
 {
@@ -308,6 +284,7 @@ int radeon_cs_parse(struct drm_device *dev, struct drm_file *file_priv,
                                DRM_ERROR("need relocate packet 3 for %x\n", reg);
                                break;
 
+                       case RADEON_3D_DRAW_IMMD:       /* triggers drawing using in-packet vertex data */
                        case RADEON_CP_3D_DRAW_IMMD_2:  /* triggers drawing using in-packet vertex data */
                        case RADEON_CP_3D_DRAW_VBUF_2:  /* triggers drawing of vertex buffers setup elsewhere */
                        case RADEON_CP_3D_DRAW_INDX_2:  /* triggers drawing using indices to vertex buffer */