Hi Hans, On Sat, Oct 06, 2018 at 11:54:38AM +0200, Hans Verkuil wrote: > Hi Ettore, > > On 10/05/2018 07:33 PM, ektor5 wrote: > > This series of patches aims to add CEC functionalities to SECO > > devices, in particular UDOO X86. > > > > The communication is achieved via Braswell SMBus (i2c-i801) to the > > onboard STM32 microcontroller that handles the CEC signals. The driver > > use direct access to the PCI addresses, due to the limitations of the > > specific driver in presence of ACPI calls. > > > > The basic functionalities are tested with success with cec-ctl and > > cec-compliance. > > This series looks good to me. But can you do one more test: > > Update your kernel to the latest media_tree master and also update your > v4l-utils repo to the latest master code. > > With all that in place please run: > > cec-compliance -A > > (have the HDMI output connected to a CEC-capable TV when running this test). > > Please report back the output of cec-compliance. > > A bunch of CEC bug fixes and improvements were merged yesterday, and the > cec-compliance adapter test is improved to check for issues that were hard > to find in the past. > > So it will be good to have a final check of this driver. Here it is, compiled media-tree and latest v4l-utils: udoo@udoo-UDOO-x86:~/v4l-utils/utils/cec-compliance$ uname -a Linux udoo-UDOO-x86 4.19.0-041900rc7-generic #201810071631+cec SMP Tue Oct 9 17:36:11 CEST 2018 x86_64 x86_64 x86_64 GNU/Linux udoo@udoo-UDOO-x86:~/v4l-utils/utils/cec-compliance$ ./cec-compliance -A cec-compliance SHA : 06ad469e966aafaf39c1cc76e6e0953ec7d4f9c9 Driver Info: Driver Name : secocec Adapter Name : CEC00001:00 Capabilities : 0x0000000e Logical Addresses Transmit Passthrough Driver version : 4.19.0 Available Logical Addresses: 1 Physical Address : 3.0.0.0 Logical Address Mask : 0x0010 CEC Version : 2.0 Vendor ID : 0x000c03 (HDMI) OSD Name : Playback Logical Addresses : 1 Logical Address : 4 (Playback Device 1) Primary Device Type : Playback Logical Address Type : Playback All Device Types : Playback RC TV Profile : None Device Features : None Compliance test for device /dev/cec0: The test results mean the following: OK Supported correctly by the device. OK (Not Supported) Not supported and not mandatory for the device. OK (Presumed) Presumably supported. Manually check to confirm. OK (Unexpected) Supported correctly but is not expected to be supported for this device. OK (Refused) Supported by the device, but was refused. FAIL Failed and was expected to be supported by this device. Find remote devices: Polling: OK CEC API: CEC_ADAP_G_CAPS: OK CEC_DQEVENT: OK CEC_ADAP_G/S_PHYS_ADDR: OK CEC_ADAP_G/S_LOG_ADDRS: OK CEC_TRANSMIT: OK CEC_RECEIVE: OK CEC_TRANSMIT/RECEIVE (non-blocking): OK (Presumed) CEC_G/S_MODE: OK fail: cec-test-adapter.cpp(1042): There were 142 pending messages for 83 transmitted messages CEC_EVENT_LOST_MSGS: FAIL Network topology: System Information for device 0 (TV) from device 4 (Playback Device 1): CEC Version : 1.4 Physical Address : 0.0.0.0 Primary Device Type : TV Vendor ID : 0x00e091 OSD Name : Tx, OK, Rx, Timeout Menu Language : kor Power Status : On Total: 10, Succeeded: 9, Failed: 1, Warnings: 0 Thanks, Ettore > > Regards, > > Hans > > > > > v2: > > - Removed useless debug prints > > - Added DMI && PCI to dependences > > - Removed useless ifdefs > > - Renamed all irda references to ir > > - Fixed SPDX clause > > - Several style fixes > > > > Ettore Chimenti (2): > > media: add SECO cec driver > > seco-cec: add Consumer-IR support > > > > MAINTAINERS | 6 + > > drivers/media/platform/Kconfig | 22 + > > drivers/media/platform/Makefile | 2 + > > drivers/media/platform/seco-cec/Makefile | 1 + > > drivers/media/platform/seco-cec/seco-cec.c | 829 +++++++++++++++++++++ > > drivers/media/platform/seco-cec/seco-cec.h | 141 ++++ > > 6 files changed, 1001 insertions(+) > > create mode 100644 drivers/media/platform/seco-cec/Makefile > > create mode 100644 drivers/media/platform/seco-cec/seco-cec.c > > create mode 100644 drivers/media/platform/seco-cec/seco-cec.h > > >