Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp1230999pxb; Wed, 4 Nov 2020 03:35:30 -0800 (PST) X-Google-Smtp-Source: ABdhPJxzp6dmmi13+Nccj32T/XPe+fm+d799p2i4ZYuCBjh5PQTp6eD27/Pmo4RN9FcqrZPHiFfg X-Received: by 2002:a17:906:e83:: with SMTP id p3mr24228723ejf.243.1604489730597; Wed, 04 Nov 2020 03:35:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604489730; cv=none; d=google.com; s=arc-20160816; b=OvY/75zTKQaD4X7RVBOYtG6joqlGEr1dV4FlRDXJED8wwivekSwQEWO+yems5GSbRb 6TLbxi3DlJHREAxW5fprxGFlLzLQO/xgP04sHaOH5pSZ7jaHbCLUJLTmlM8IxrMlQE4w fyuRyOKd2/y2XDCIp1//C4J1sbm5iUXDf5ncMbYNjMKGp/DUrihR/F0PYVe146SwYrz0 Unhsm2exhoX8QEmaWJQKQVE8AxuKqYKERetTK6IpgvbTN1CiNstDG9nivpRAJ9uF+GOQ AZULCRryy11DRXtQcFOf4ggCvn1x05w+MR+XhMGVnCwlo+s/o4me4pbnzW1qrb4zQZMN y1MQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=IY8NX9op+e3GUd4rTZj8S7s9fDtEYhW9AdwpdNxsDds=; b=fEdpDDtAEKomWjQyC3bDyRKH3m9uHvsL/2nMeCoUwDCpCVnSuN7Mx+2ieTnO2itFpg t+f85kn9oxBspEr1BiZHhHDDcx94/xR8vLx6GA7qekRWlK4g2Xu/gElj20ylZVmdLTCD /7v5My+c8wq56MB6W8FgvW9BztHtdlT8vaH23SEk8XgVv0UpzwYcLGIQBQFY++2S5wWr KCI4Nzb6daQL5uMtKuUBFtiUp4+BmdO4BARsImUPOIdocQC4IcSxV7FkGtT6nhIWM8NT ESkmxS2UwlZw0p237kUFrNnNeC1PbntRe8uF/iYKa2DchUDxvp85GRd18KvQtMwBqVqI KFBg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=DzyXItOo; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id qq25si1183456ejb.546.2020.11.04.03.35.06; Wed, 04 Nov 2020 03:35:30 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=DzyXItOo; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729421AbgKDLd2 (ORCPT + 99 others); Wed, 4 Nov 2020 06:33:28 -0500 Received: from perceval.ideasonboard.com ([213.167.242.64]:56970 "EHLO perceval.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728700AbgKDLd1 (ORCPT ); Wed, 4 Nov 2020 06:33:27 -0500 Received: from pendragon.ideasonboard.com (62-78-145-57.bb.dnainternet.fi [62.78.145.57]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 7F1B5563; Wed, 4 Nov 2020 12:33:25 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1604489605; bh=qzViUK5hol1fctUVlmPguaB97Qe8i4d37GxIVLbu4Ag=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=DzyXItOo7m457X/5XsqvQ/1NOEh3X8QwkHrMBEZP0n22hU8tj5BITmg6HQsyLCIpA FJvNliFXgguUxgOtU0TRcx3OdQJoPhDmPx/bxm5+IGOuQIJ9vzi3JD3Fb9zQfY72ge DpFK1KdCcVCu547WsEwU/ykgB9cXmVR0GeW4s8Ms= Date: Wed, 4 Nov 2020 13:32:38 +0200 From: Laurent Pinchart To: Ricardo Ribalda Cc: Mauro Carvalho Chehab , linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, tfiga@chromium.org Subject: Re: [PATCH 3/6] media: uvcvideo: Add UVC_GUID_EXT_GPIO_CONTROLLER Message-ID: <20201104113238.GI26171@pendragon.ideasonboard.com> References: <20201022133753.310506-1-ribalda@chromium.org> <20201022133753.310506-4-ribalda@chromium.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20201022133753.310506-4-ribalda@chromium.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Ricardo, Thank you for the patch. On Thu, Oct 22, 2020 at 03:37:50PM +0200, Ricardo Ribalda wrote: > Create a new GUID for GPIO controller entities that do not belong to the > USB video device. > > This GUID is selected on an address range completely different that the > UVC standard to avoid collisions. I'd squash this patch with 5/6. > Signed-off-by: Ricardo Ribalda > --- > drivers/media/usb/uvc/uvc_ctrl.c | 4 ++++ > drivers/media/usb/uvc/uvcvideo.h | 3 +++ > 2 files changed, 7 insertions(+) > > diff --git a/drivers/media/usb/uvc/uvc_ctrl.c b/drivers/media/usb/uvc/uvc_ctrl.c > index 0a8835742d49..913739915863 100644 > --- a/drivers/media/usb/uvc/uvc_ctrl.c > +++ b/drivers/media/usb/uvc/uvc_ctrl.c > @@ -830,6 +830,7 @@ static const u8 uvc_processing_guid[16] = UVC_GUID_UVC_PROCESSING; > static const u8 uvc_camera_guid[16] = UVC_GUID_UVC_CAMERA; > static const u8 uvc_media_transport_input_guid[16] = > UVC_GUID_UVC_MEDIA_TRANSPORT_INPUT; > +static const u8 uvc_gpio_guid[16] = UVC_GUID_EXT_GPIO_CONTROLLER; > > static int uvc_entity_match_guid(const struct uvc_entity *entity, > const u8 guid[16]) > @@ -848,6 +849,9 @@ static int uvc_entity_match_guid(const struct uvc_entity *entity, > return memcmp(entity->extension.guidExtensionCode, > guid, 16) == 0; > > + case UVC_GPIO_UNIT: This won't compile, UVC_GPIO_UNIT is defined in 5/6. > + return memcmp(uvc_gpio_guid, guid, 16) == 0; I wonder if it would make sense to store the GUID in the uvc_entity structure instead of adding new entries to this function. > + > default: > return 0; > } > diff --git a/drivers/media/usb/uvc/uvcvideo.h b/drivers/media/usb/uvc/uvcvideo.h > index 08922d889bb6..8e5a9fc35820 100644 > --- a/drivers/media/usb/uvc/uvcvideo.h > +++ b/drivers/media/usb/uvc/uvcvideo.h > @@ -56,6 +56,9 @@ > #define UVC_GUID_UVC_SELECTOR \ > {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, \ > 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x02} None of the GUIDs above are defined by the UVC specification. You could use { 0x00 * 14, 0x01, 0x03 } or { 0x00 * 14, 0x02, 0x01 } instead of going for 0xff. Not that it matters much, it's all internal. > +#define UVC_GUID_EXT_GPIO_CONTROLLER \ > + {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf, \ I assume the last value was meant to be 0xff ? > + 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x01} > > #define UVC_GUID_FORMAT_MJPEG \ > { 'M', 'J', 'P', 'G', 0x00, 0x00, 0x10, 0x00, \ -- Regards, Laurent Pinchart