aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/radeon/radeon_atombios.c
diff options
context:
space:
mode:
authorAlex Deucher <alexander.deucher@amd.com>2013-08-27 12:36:01 -0400
committerAlex Deucher <alexander.deucher@amd.com>2013-08-30 16:31:10 -0400
commitfb93df1c2d8b3b1fb16d6ee9e32554e0c038815d (patch)
tree2a5e0d1342df685ec93851d3b6d683058a2ed9a3 /drivers/gpu/drm/radeon/radeon_atombios.c
parentacf88deb8ddbb73acd1c3fa32fde51af9153227f (diff)
drm/radeon: fix handling of variable sized arrays for router objects
The table has the following format: typedef struct _ATOM_SRC_DST_TABLE_FOR_ONE_OBJECT //usSrcDstTableOffset pointing to this structure { UCHAR ucNumberOfSrc; USHORT usSrcObjectID[1]; UCHAR ucNumberOfDst; USHORT usDstObjectID[1]; }ATOM_SRC_DST_TABLE_FOR_ONE_OBJECT; usSrcObjectID[] and usDstObjectID[] are variably sized, so we can't access them directly. Use pointers and update the offset appropriately when accessing the Dst members. Signed-off-by: Alex Deucher <alexander.deucher@amd.com> Cc: stable@vger.kernel.org
Diffstat (limited to 'drivers/gpu/drm/radeon/radeon_atombios.c')
-rw-r--r--drivers/gpu/drm/radeon/radeon_atombios.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_atombios.c b/drivers/gpu/drm/radeon/radeon_atombios.c
index 112c96352562..ad913542ec1a 100644
--- a/drivers/gpu/drm/radeon/radeon_atombios.c
+++ b/drivers/gpu/drm/radeon/radeon_atombios.c
@@ -711,13 +711,16 @@ bool radeon_get_atom_connector_info_from_object_table(struct drm_device *dev)
711 (ATOM_SRC_DST_TABLE_FOR_ONE_OBJECT *) 711 (ATOM_SRC_DST_TABLE_FOR_ONE_OBJECT *)
712 (ctx->bios + data_offset + 712 (ctx->bios + data_offset +
713 le16_to_cpu(router_obj->asObjects[k].usSrcDstTableOffset)); 713 le16_to_cpu(router_obj->asObjects[k].usSrcDstTableOffset));
714 u8 *num_dst_objs = (u8 *)
715 ((u8 *)router_src_dst_table + 1 +
716 (router_src_dst_table->ucNumberOfSrc * 2));
717 u16 *dst_objs = (u16 *)(num_dst_objs + 1);
714 int enum_id; 718 int enum_id;
715 719
716 router.router_id = router_obj_id; 720 router.router_id = router_obj_id;
717 for (enum_id = 0; enum_id < router_src_dst_table->ucNumberOfDst; 721 for (enum_id = 0; enum_id < (*num_dst_objs); enum_id++) {
718 enum_id++) {
719 if (le16_to_cpu(path->usConnObjectId) == 722 if (le16_to_cpu(path->usConnObjectId) ==
720 le16_to_cpu(router_src_dst_table->usDstObjectID[enum_id])) 723 le16_to_cpu(dst_objs[enum_id]))
721 break; 724 break;
722 } 725 }
723 726