Re: [PATCH] [media] cec: GIVE_PHYSICAL_ADDR should respond to unregistered device

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 09/14/17 15:28, Jose Abreu wrote:
> Hi Hans,
> 
> On 14-09-2017 14:10, Hans Verkuil wrote:
>> On 09/14/17 13:33, Jose Abreu wrote:
>>> Running CEC 1.4 compliance test we get the following error on test
>>> 11.1.6.2: "ERROR: The DUT did not broadcast a
>>> <Report Physical Address> message to the unregistered device."
>>>
>>> Fix this by letting GIVE_PHYSICAL_ADDR message respond to unregistered
>>> device.
>>>
>>> With this fix we pass CEC 1.4 official compliance.
>>>
>>> Signed-off-by: Jose Abreu <joabreu@xxxxxxxxxxxx>
>>> Cc: Hans Verkuil <hans.verkuil@xxxxxxxxx>
>>> Cc: Joao Pinto <jpinto@xxxxxxxxxxxx>
>>> ---
>>>  drivers/media/cec/cec-adap.c | 7 +++++--
>>>  1 file changed, 5 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/drivers/media/cec/cec-adap.c b/drivers/media/cec/cec-adap.c
>>> index dd769e4..48482aa 100644
>>> --- a/drivers/media/cec/cec-adap.c
>>> +++ b/drivers/media/cec/cec-adap.c
>>> @@ -1797,9 +1797,12 @@ static int cec_receive_notify(struct cec_adapter *adap, struct cec_msg *msg,
>>>  	case CEC_MSG_GIVE_DEVICE_VENDOR_ID:
>>>  	case CEC_MSG_ABORT:
>>>  	case CEC_MSG_GIVE_DEVICE_POWER_STATUS:
>>> -	case CEC_MSG_GIVE_PHYSICAL_ADDR:
>>>  	case CEC_MSG_GIVE_OSD_NAME:
>>>  	case CEC_MSG_GIVE_FEATURES:
>>> +		if (from_unregistered)
>> This should be (!adap->passthrough && from_unregistered)
> 
> Ok.
> 
>>
>>> +			return 0;
>> Actually, CEC_MSG_GIVE_DEVICE_VENDOR_ID and CEC_MSG_GIVE_FEATURES
>> fall in the same category as CEC_MSG_GIVE_PHYSICAL_ADDR. I.e. these are
>> directed messages but the reply is a broadcast message. All three can be
>> sent by an unregistered device. It's a good idea to mention this here.
>> I.e. something like:
>>
>> 		/* These messages reply with a directed message, so ignore if
>> 		   the initiator is Unregistered */
> 
> Ok, but this comment applies to the remaining msgs, right? I
> mean, GIVE_DEVICE_VENDOR_ID, GIVE_FEATURES and GIVE_PHYSICAL_ADDR
> will still send a response if initiator is unregistered, correct?

No, I meant this to go right before the 'if (!adap->passthrough && from_unregistered)'
statement. Sorry for the confusion.

> 
>>
>>> +		/* Fall through */
>>> +	case CEC_MSG_GIVE_PHYSICAL_ADDR:
>>>  		/*
>>>  		 * Skip processing these messages if the passthrough mode
>>>  		 * is on.
>>> @@ -1807,7 +1810,7 @@ static int cec_receive_notify(struct cec_adapter *adap, struct cec_msg *msg,
>>>  		if (adap->passthrough)
>>>  			goto skip_processing;
>>>  		/* Ignore if addressing is wrong */
>>> -		if (is_broadcast || from_unregistered)
>>> +		if (is_broadcast)
>>>  			return 0;
>>>  		break;
>>>  
>>>
>> Good catch, if you can make a v2 then I'll get this in for 4.14.
>>
>> Not bad, just one obscure compliance error!
> 
> Actually, I have at least one more fix which I don't know if it's
> valid and I didn't manage to actually write it in a nice way.
> This one is for CEC 2.0. My test equipment (which is certified)
> in some tests sends msgs only with the opcode. As the received
> msg length does not match the expected one CEC core is rejecting
> the message and my compliance test is failling (test is 4.2.3).

In the HDMI 1.4 spec in CEC 7.3 (Frame Validation) it says that a follower
should ignore frames that are too small.

At the same time unsupported opcodes should result in a Feature Abort.

If you don't send a properly formed message, then it's not clear to me
what should happen. Which opcode failed?

> Have you run this test? Did it pass?

No, we haven't. Never got around to that.

Regards,

	Hans

> 
> Best regards,
> Jose Miguel Abreu
> 
>>
>> Regards,
>>
>> 	Hans
> 




[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux