|
@@ -780,33 +780,28 @@ static int r600_cs_packet_parse_vline(struct radeon_cs_parser *p)
|
|
|
if (wait_reg_mem.type != PACKET_TYPE3 ||
|
|
|
wait_reg_mem.opcode != PACKET3_WAIT_REG_MEM) {
|
|
|
DRM_ERROR("vline wait missing WAIT_REG_MEM segment\n");
|
|
|
- r = -EINVAL;
|
|
|
- return r;
|
|
|
+ return -EINVAL;
|
|
|
}
|
|
|
|
|
|
wait_reg_mem_info = radeon_get_ib_value(p, wait_reg_mem.idx + 1);
|
|
|
/* bit 4 is reg (0) or mem (1) */
|
|
|
if (wait_reg_mem_info & 0x10) {
|
|
|
DRM_ERROR("vline WAIT_REG_MEM waiting on MEM rather than REG\n");
|
|
|
- r = -EINVAL;
|
|
|
- return r;
|
|
|
+ return -EINVAL;
|
|
|
}
|
|
|
/* waiting for value to be equal */
|
|
|
if ((wait_reg_mem_info & 0x7) != 0x3) {
|
|
|
DRM_ERROR("vline WAIT_REG_MEM function not equal\n");
|
|
|
- r = -EINVAL;
|
|
|
- return r;
|
|
|
+ return -EINVAL;
|
|
|
}
|
|
|
if ((radeon_get_ib_value(p, wait_reg_mem.idx + 2) << 2) != AVIVO_D1MODE_VLINE_STATUS) {
|
|
|
DRM_ERROR("vline WAIT_REG_MEM bad reg\n");
|
|
|
- r = -EINVAL;
|
|
|
- return r;
|
|
|
+ return -EINVAL;
|
|
|
}
|
|
|
|
|
|
if (radeon_get_ib_value(p, wait_reg_mem.idx + 5) != AVIVO_D1MODE_VLINE_STAT) {
|
|
|
DRM_ERROR("vline WAIT_REG_MEM bad bit mask\n");
|
|
|
- r = -EINVAL;
|
|
|
- return r;
|
|
|
+ return -EINVAL;
|
|
|
}
|
|
|
|
|
|
/* jump over the NOP */
|
|
@@ -825,8 +820,7 @@ static int r600_cs_packet_parse_vline(struct radeon_cs_parser *p)
|
|
|
obj = drm_mode_object_find(p->rdev->ddev, crtc_id, DRM_MODE_OBJECT_CRTC);
|
|
|
if (!obj) {
|
|
|
DRM_ERROR("cannot find crtc %d\n", crtc_id);
|
|
|
- r = -EINVAL;
|
|
|
- goto out;
|
|
|
+ return -EINVAL;
|
|
|
}
|
|
|
crtc = obj_to_crtc(obj);
|
|
|
radeon_crtc = to_radeon_crtc(crtc);
|
|
@@ -849,14 +843,13 @@ static int r600_cs_packet_parse_vline(struct radeon_cs_parser *p)
|
|
|
break;
|
|
|
default:
|
|
|
DRM_ERROR("unknown crtc reloc\n");
|
|
|
- r = -EINVAL;
|
|
|
- goto out;
|
|
|
+ return -EINVAL;
|
|
|
}
|
|
|
ib[h_idx] = header;
|
|
|
ib[h_idx + 4] = AVIVO_D2MODE_VLINE_STATUS >> 2;
|
|
|
}
|
|
|
-out:
|
|
|
- return r;
|
|
|
+
|
|
|
+ return 0;
|
|
|
}
|
|
|
|
|
|
static int r600_packet0_check(struct radeon_cs_parser *p,
|