[PATCH] drm/radeon: fix atom aux payload size check for writes

Michel Dänzer michel at daenzer.net
Sun Feb 22 19:54:17 PST 2015


On 21.02.2015 01:56, Alex Deucher wrote:
> The atom aux param interface only supports 4 bits for
> the total write transfer size (header + payload).  This
> limits us to 12 bytes of payload rather than 16.  Add a
> check for this. Reads are not affected.
> 
> Signed-off-by: Alex Deucher <alexander.deucher at amd.com>
> ---
>  drivers/gpu/drm/radeon/atombios_dp.c | 7 +++++++
>  1 file changed, 7 insertions(+)
> 
> diff --git a/drivers/gpu/drm/radeon/atombios_dp.c b/drivers/gpu/drm/radeon/atombios_dp.c
> index 5bf825d..c57706e6 100644
> --- a/drivers/gpu/drm/radeon/atombios_dp.c
> +++ b/drivers/gpu/drm/radeon/atombios_dp.c
> @@ -178,6 +178,13 @@ radeon_dp_aux_transfer(struct drm_dp_aux *aux, struct drm_dp_aux_msg *msg)
>  	switch (msg->request & ~DP_AUX_I2C_MOT) {
>  	case DP_AUX_NATIVE_WRITE:
>  	case DP_AUX_I2C_WRITE:
> +		/* The atom implementation only supports writes with a max payload of
> +		 * 12 bytes since it uses 4 bits for the total count (header + payload)
> +		 * in the parameter space.  The atom interface supports 16 byte
> +		 * payloads for reads. The hw itself supports up to 16 bytes of payload.
> +		 */
> +		if (WARN_ON(msg->size > 12))
> +			return -E2BIG;
>  		/* tx_size needs to be 4 even for bare address packets since the atom
>  		 * table needs the info in tx_buf[3].
>  		 */
> 

Might be safer to use WARN_ON_ONCE to avoid spamming dmesg if the
warning ever gets triggered.


-- 
Earthling Michel Dänzer               |               http://www.amd.com
Libre software enthusiast             |             Mesa and X developer


More information about the dri-devel mailing list