Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp19870128rwd; Wed, 28 Jun 2023 15:55:27 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ7hC361EnLFA5ZsgpxXusrsASXQibgImD79YC3yN3oVMHzt2OJAqIHrVwmZ2EjZC3dmY5cY X-Received: by 2002:a05:6a00:1813:b0:67c:2b7b:23d7 with SMTP id y19-20020a056a00181300b0067c2b7b23d7mr8213594pfa.21.1687992927190; Wed, 28 Jun 2023 15:55:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1687992927; cv=none; d=google.com; s=arc-20160816; b=IeojvfoS8khqNWvBQFToivC1eq4Cbvize4vkAzarH6KW4HnMP6aYBzda5sGdQJeKXK uI14kZemIXDLc9dmD2qsiqAtG2LNirtVm574mcJWuVn7q9P75aHvVtkGzXP8/A/F6k9X +/cl2poY/B9y1GZiiev3WkR5KhY96cD6gPBNSSi/yfXL9z4mhQYPeg3/+TkzIFywNlP7 EsqbdMqmlfbRu38HXSvll47qIUsDQh1HG8XiZ9sG/GIkZqIbBuQdPJZ5JJiLLQDpeLLg qkB/ZoAQe8XgcfI0mS3+76QJRabxNKhJsXfHRhAEHvpFFYWh+TEIFjxWomiWZjQUJmgB HChA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:message-id:date:to:cc:from:subject :references:in-reply-to:content-transfer-encoding:mime-version :dkim-signature; bh=He+G9IDPX8XqNHLKOL3HDAXdDTQ5zlnranpDy/8s0zs=; fh=9/h3Bfv7+tJRg4Cg0ZJunioPC8qN6sauW1t085AXrJg=; b=NLndTAeIlP0/tCSAZVRTffCooGBt3cfrqpNl56SjCrBgXnCFnPhFn8Bl7B1ooxjogm HqvPubQVxaI9scq0fBTnEYjxY9eN0Ji8x4C0J8j9QfY/ajN/hY788Hu/6AtE/Dq3SANf 2k1qvDVJmk07TmMm8B1OzKHn3tKXnEjJ0U+JtGVf58swkj2EU9Ie5hHJIUaL2O6DtaSl ADW9rad0WoAn3hdfWs7p6wMhn1gXIwI0dANqH0/58C6J/a7mgwgP5PTxFpEdfdGJDRMD YVjyDe9QNAmFBAynZ7cpJSHnRJx4Ep3joDwaC/6Ntv0pbgTMG8dnMvu05zgAidfKNcEE /CdQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=iJ6U8CHr; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id k13-20020a056a00134d00b0066877f29ed3si1745184pfu.105.2023.06.28.15.55.13; Wed, 28 Jun 2023 15:55:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=iJ6U8CHr; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231693AbjF1Ws0 (ORCPT + 99 others); Wed, 28 Jun 2023 18:48:26 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50130 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231650AbjF1Wr4 (ORCPT ); Wed, 28 Jun 2023 18:47:56 -0400 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [IPv6:2001:4b98:dc2:55:216:3eff:fef7:d647]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 322063C0E; Wed, 28 Jun 2023 15:44:37 -0700 (PDT) Received: from pendragon.ideasonboard.com (aztw-30-b2-v4wan-166917-cust845.vm26.cable.virginm.net [82.37.23.78]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 2139C905; Thu, 29 Jun 2023 00:43:54 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1687992234; bh=8kUftu7lYSaZy3TqVKWV5nfS/HXx3yf+27+tAyJIkyk=; h=In-Reply-To:References:Subject:From:Cc:To:Date:From; b=iJ6U8CHr0KCHygB+rhCg58KJj/2gAUDwcbI9GZA/3cbYVkCDbLNSPNJUxRiMOBxL3 6QXplw2JoYKR1UHRlsFcIzvHMwb7eoxrf01EKEtVm0T6qZI2y2Pw1JRea8swrf7opv B20v0j+nvh6J8xT2iNTjwNljt9CnWsDOkTD0aplY= Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable In-Reply-To: <20230627201628.207483-4-umang.jain@ideasonboard.com> References: <20230627201628.207483-1-umang.jain@ideasonboard.com> <20230627201628.207483-4-umang.jain@ideasonboard.com> Subject: Re: [PATCH v8 3/5] staging: bcm2835-camera: Register bcm2835-camera with vchiq_bus_type From: Kieran Bingham Cc: stefan.wahren@i2se.com, gregkh@linuxfoundation.org, f.fainelli@gmail.com, athierry@redhat.com, error27@gmail.com, dave.stevenson@raspberrypi.com, laurent.pinchart@ideasonboard.com, Umang Jain To: Umang Jain , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-media@vger.kernel.org, linux-rpi-kernel@lists.infradead.org, linux-staging@lists.linux.dev Date: Wed, 28 Jun 2023 23:44:31 +0100 Message-ID: <168799227183.3298351.12365161998104715465@Monstersaurus> User-Agent: alot/0.10 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS, T_SCC_BODY_TEXT_LINE,T_SPF_TEMPERROR,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Quoting Umang Jain (2023-06-27 21:16:26) > Register the bcm2835-camera with the vchiq_bus_type instead of using > platform driver/device. >=20 > Also the VCHIQ firmware doesn't support device enumeration, hence > one has to maintain a list of devices to be registered in the interface. >=20 > Signed-off-by: Umang Jain > --- > .../bcm2835-camera/bcm2835-camera.c | 16 +++++++------- > .../interface/vchiq_arm/vchiq_arm.c | 21 ++++++++++++++++--- > 2 files changed, 26 insertions(+), 11 deletions(-) >=20 > diff --git a/drivers/staging/vc04_services/bcm2835-camera/bcm2835-camera.= c b/drivers/staging/vc04_services/bcm2835-camera/bcm2835-camera.c > index 346d00df815a..f37b2a881d92 100644 > --- a/drivers/staging/vc04_services/bcm2835-camera/bcm2835-camera.c > +++ b/drivers/staging/vc04_services/bcm2835-camera/bcm2835-camera.c > @@ -24,8 +24,9 @@ > #include > #include > #include > -#include > =20 > +#include "../interface/vchiq_arm/vchiq_arm.h" > +#include "../interface/vchiq_arm/vchiq_device.h" > #include "../vchiq-mmal/mmal-common.h" > #include "../vchiq-mmal/mmal-encodings.h" > #include "../vchiq-mmal/mmal-vchiq.h" > @@ -1841,7 +1842,7 @@ static struct v4l2_format default_v4l2_format =3D { > .fmt.pix.sizeimage =3D 1024 * 768, > }; > =20 > -static int bcm2835_mmal_probe(struct platform_device *pdev) > +static int bcm2835_mmal_probe(struct vchiq_device *device) > { > int ret; > struct bcm2835_mmal_dev *dev; > @@ -1896,7 +1897,7 @@ static int bcm2835_mmal_probe(struct platform_devic= e *pdev) > &camera_instance); > ret =3D v4l2_device_register(NULL, &dev->v4l2_dev); > if (ret) { > - dev_err(&pdev->dev, "%s: could not register V4L2 = device: %d\n", > + dev_err(&device->dev, "%s: could not register V4L= 2 device: %d\n", > __func__, ret); > goto free_dev; > } > @@ -1976,7 +1977,7 @@ static int bcm2835_mmal_probe(struct platform_devic= e *pdev) > return ret; > } > =20 > -static void bcm2835_mmal_remove(struct platform_device *pdev) > +static void bcm2835_mmal_remove(struct vchiq_device *device) > { > int camera; > struct vchiq_mmal_instance *instance =3D gdev[0]->instance; > @@ -1988,17 +1989,16 @@ static void bcm2835_mmal_remove(struct platform_d= evice *pdev) > vchiq_mmal_finalise(instance); > } > =20 > -static struct platform_driver bcm2835_camera_driver =3D { > +static struct vchiq_driver bcm2835_camera_driver =3D { > .probe =3D bcm2835_mmal_probe, > - .remove_new =3D bcm2835_mmal_remove, > + .remove =3D bcm2835_mmal_remove, > .driver =3D { > .name =3D "bcm2835-camera", > }, > }; > =20 > -module_platform_driver(bcm2835_camera_driver) > +module_vchiq_driver(bcm2835_camera_driver) > =20 > MODULE_DESCRIPTION("Broadcom 2835 MMAL video capture"); > MODULE_AUTHOR("Vincent Sanders"); > MODULE_LICENSE("GPL"); > -MODULE_ALIAS("platform:bcm2835-camera"); This bit worries me. I think that's how module autoloading is handled. Can you check into the details of MODULE_ALIAS and follow the rabbit hole for a bit? It's a few years since I last went down there so I can't remember the specifics right now. Except for that, I think this looks good. > diff --git a/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.= c b/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c > index e8d40f891449..79d4d0eeb5fb 100644 > --- a/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c > +++ b/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c > @@ -67,7 +67,6 @@ int vchiq_susp_log_level =3D VCHIQ_LOG_ERROR; > DEFINE_SPINLOCK(msg_queue_spinlock); > struct vchiq_state g_state; > =20 > -static struct platform_device *bcm2835_camera; > static struct platform_device *bcm2835_audio; > =20 > struct vchiq_drvdata { > @@ -134,6 +133,15 @@ struct vchiq_pagelist_info { > unsigned int scatterlist_mapped; > }; > =20 > +/* > + * The devices implemented in the VCHIQ firmware are not discoverable, > + * so we need to maintain a list of them in order to register them with > + * the interface. > + */ > +static const char *const vchiq_devices[] =3D { > + "bcm2835-camera", > +}; > + > static void __iomem *g_regs; > /* This value is the size of the L2 cache lines as understood by the > * VPU firmware, which determines the required alignment of the > @@ -1798,6 +1806,7 @@ static int vchiq_probe(struct platform_device *pdev) > struct device_node *fw_node; > const struct of_device_id *of_id; > struct vchiq_drvdata *drvdata; > + unsigned int i; > int err; > =20 > of_id =3D of_match_node(vchiq_of_match, pdev->dev.of_node); > @@ -1840,9 +1849,15 @@ static int vchiq_probe(struct platform_device *pde= v) > goto error_exit; > } > =20 > - bcm2835_camera =3D vchiq_register_child(pdev, "bcm2835-camera"); > bcm2835_audio =3D vchiq_register_child(pdev, "bcm2835_audio"); > =20 > + for (i =3D 0; i < ARRAY_SIZE(vchiq_devices); i++) { > + err =3D vchiq_device_register(&pdev->dev, vchiq_devices[i= ]); > + if (err) > + dev_err(&pdev->dev, "Failed to register %s vchiq = device\n", > + vchiq_devices[i]); > + } > + > return 0; > =20 > failed_platform_init: > @@ -1854,7 +1869,7 @@ static int vchiq_probe(struct platform_device *pdev) > static void vchiq_remove(struct platform_device *pdev) > { > platform_device_unregister(bcm2835_audio); > - platform_device_unregister(bcm2835_camera); > + bus_for_each_dev(&vchiq_bus_type, NULL, NULL, vchiq_device_unregi= ster); > vchiq_debugfs_deinit(); > vchiq_deregister_chrdev(); > } > --=20 > 2.39.1 >