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 >