From patchwork Tue Aug 24 14:24:47 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Kieran Bingham X-Patchwork-Id: 13463 Return-Path: X-Original-To: parsemail@patchwork.libcamera.org Delivered-To: parsemail@patchwork.libcamera.org Received: from lancelot.ideasonboard.com (lancelot.ideasonboard.com [92.243.16.209]) by patchwork.libcamera.org (Postfix) with ESMTPS id BA7A2C3241 for ; Tue, 24 Aug 2021 14:25:00 +0000 (UTC) Received: from lancelot.ideasonboard.com (localhost [IPv6:::1]) by lancelot.ideasonboard.com (Postfix) with ESMTP id 5A15268919; Tue, 24 Aug 2021 16:25:00 +0200 (CEST) Authentication-Results: lancelot.ideasonboard.com; dkim=fail reason="signature verification failed" (1024-bit key; unprotected) header.d=ideasonboard.com header.i=@ideasonboard.com header.b="HgHdRASD"; dkim-atps=neutral Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [213.167.242.64]) by lancelot.ideasonboard.com (Postfix) with ESMTPS id 6E13B688C4 for ; Tue, 24 Aug 2021 16:24:56 +0200 (CEST) Received: from Monstersaurus.local (cpc89244-aztw30-2-0-cust3082.18-1.cable.virginm.net [86.31.172.11]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 172333F0; Tue, 24 Aug 2021 16:24:55 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1629815095; bh=B3zrvpiFuR119fYKAR7dixmI8rpS7lMvWvhVNUsyPII=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=HgHdRASDekk8prZt4oR7elhWu2XDzS7OSuK3jLd1OL0w/fd/ux3gK8ya71frV7Wn/ lzKoPm6jsOBoqNh96eoqQllo7uBh1Erfdnqfl2K+8R1935R7gj6XLtpkiJX4H4lJbe kO9WjKfJ2qUnYvXg10bnQ5Y3t3nHid3WjJuUhH/I= From: Kieran Bingham To: libcamera devel Date: Tue, 24 Aug 2021 15:24:47 +0100 Message-Id: <20210824142450.3157833-2-kieran.bingham@ideasonboard.com> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210824142450.3157833-1-kieran.bingham@ideasonboard.com> References: <20210824142450.3157833-1-kieran.bingham@ideasonboard.com> MIME-Version: 1.0 Subject: [libcamera-devel] [SimpleCam PATCH 1/4] simple-cam: Use a unique_ptr for the CameraManager X-BeenThere: libcamera-devel@lists.libcamera.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: libcamera-devel-bounces@lists.libcamera.org Sender: "libcamera-devel" The CameraManager should be released when it is no longer used. A unique_ptr will handle this automatically, and convey the lifetime of the object. Update simple-cam to show that managing the lifetime of the CameraManager is recommended practice. Signed-off-by: Kieran Bingham Reviewed-by: Jacopo Mondi Reviewed-by: Laurent Pinchart --- simple-cam.cpp | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/simple-cam.cpp b/simple-cam.cpp index 8f7012b83b6c..5c16db67700c 100644 --- a/simple-cam.cpp +++ b/simple-cam.cpp @@ -131,8 +131,15 @@ int main() * * The CameraManager provides a list of available Cameras that * applications can operate on. + * + * When the CameraManager is no longer to be used, it should be deleted. + * We use a unique_ptr here to manage the lifetime automatically during + * the scope of this function. + * + * There can only be a single CameraManager constructed within any + * process space. */ - CameraManager *cm = new CameraManager(); + std::unique_ptr cm = std::make_unique(); cm->start(); /* From patchwork Tue Aug 24 14:24:48 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Kieran Bingham X-Patchwork-Id: 13460 Return-Path: X-Original-To: parsemail@patchwork.libcamera.org Delivered-To: parsemail@patchwork.libcamera.org Received: from lancelot.ideasonboard.com (lancelot.ideasonboard.com [92.243.16.209]) by patchwork.libcamera.org (Postfix) with ESMTPS id 760FFBD87D for ; Tue, 24 Aug 2021 14:24:58 +0000 (UTC) Received: from lancelot.ideasonboard.com (localhost [IPv6:::1]) by lancelot.ideasonboard.com (Postfix) with ESMTP id 3470E6890C; Tue, 24 Aug 2021 16:24:58 +0200 (CEST) Authentication-Results: lancelot.ideasonboard.com; dkim=fail reason="signature verification failed" (1024-bit key; unprotected) header.d=ideasonboard.com header.i=@ideasonboard.com header.b="o4JCQjj+"; dkim-atps=neutral Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [213.167.242.64]) by lancelot.ideasonboard.com (Postfix) with ESMTPS id AD26E60505 for ; Tue, 24 Aug 2021 16:24:55 +0200 (CEST) Received: from Monstersaurus.local (cpc89244-aztw30-2-0-cust3082.18-1.cable.virginm.net [86.31.172.11]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 528E1BB0; Tue, 24 Aug 2021 16:24:55 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1629815095; bh=twq6yGjSB8kHCTaxcagHrXyuUDPduGOV7Sjn0uuA3xE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=o4JCQjj+ddymsjRVBZpwidCeurOuZ3CtZdQVtgbf7j2+urDP7iIfF1LnHSRVNM/4a BqQWKM4bYKcX3Y7EOdUaJgZU2fF0/KsO0mVquSX9gl8+y8LIVC5REPqCni2SzmfYCQ 3hooEg0C8MoXzFxxj7C9/nygJSFmWws4uSRQXdl0= From: Kieran Bingham To: libcamera devel Date: Tue, 24 Aug 2021 15:24:48 +0100 Message-Id: <20210824142450.3157833-3-kieran.bingham@ideasonboard.com> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210824142450.3157833-1-kieran.bingham@ideasonboard.com> References: <20210824142450.3157833-1-kieran.bingham@ideasonboard.com> MIME-Version: 1.0 Subject: [libcamera-devel] [SimpleCam PATCH 2/4] simple-cam: Improve documentation of validate/configure X-BeenThere: libcamera-devel@lists.libcamera.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: libcamera-devel-bounces@lists.libcamera.org Sender: "libcamera-devel" The validation and configure phase has a couple of grammatical errors. Fix them and reflow the text accordingly. Signed-off-by: Kieran Bingham Reviewed-by: Jacopo Mondi Reviewed-by: Laurent Pinchart --- simple-cam.cpp | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/simple-cam.cpp b/simple-cam.cpp index 5c16db67700c..2e646a5485c9 100644 --- a/simple-cam.cpp +++ b/simple-cam.cpp @@ -255,16 +255,17 @@ int main() #endif /* - * Validating a CameraConfiguration -before- applying it adjust it - * to a valid configuration as closest as possible to the requested one. + * Validating a CameraConfiguration -before- applying it will adjust it + * to a valid configuration which is as close as possible to the one + * requested. */ config->validate(); std::cout << "Validated viewfinder configuration is: " << streamConfig.toString() << std::endl; /* - * Once we have a validate configuration, we can apply it - * to the Camera. + * Once we have a validated configuration, we can apply it to the + * Camera. */ camera->configure(config.get()); From patchwork Tue Aug 24 14:24:49 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Kieran Bingham X-Patchwork-Id: 13461 Return-Path: X-Original-To: parsemail@patchwork.libcamera.org Delivered-To: parsemail@patchwork.libcamera.org Received: from lancelot.ideasonboard.com (lancelot.ideasonboard.com [92.243.16.209]) by patchwork.libcamera.org (Postfix) with ESMTPS id 51589C3241 for ; Tue, 24 Aug 2021 14:24:59 +0000 (UTC) Received: from lancelot.ideasonboard.com (localhost [IPv6:::1]) by lancelot.ideasonboard.com (Postfix) with ESMTP id A45E568915; Tue, 24 Aug 2021 16:24:58 +0200 (CEST) Authentication-Results: lancelot.ideasonboard.com; dkim=fail reason="signature verification failed" (1024-bit key; unprotected) header.d=ideasonboard.com header.i=@ideasonboard.com header.b="mu6uTAK2"; dkim-atps=neutral Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [IPv6:2001:4b98:dc2:55:216:3eff:fef7:d647]) by lancelot.ideasonboard.com (Postfix) with ESMTPS id 0B7CC688AC for ; Tue, 24 Aug 2021 16:24:55 +0200 (CEST) Received: from Monstersaurus.local (cpc89244-aztw30-2-0-cust3082.18-1.cable.virginm.net [86.31.172.11]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 8A5E82A5; Tue, 24 Aug 2021 16:24:55 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1629815095; bh=SXqO+Ipt5H3+sDUt8BwZBIa/fGhEht3o/pU33f5A9u4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=mu6uTAK2HQKKheBHUieYKe3l2QhgrGH1YHzjNjGo7YKySc7u+c6X+FNabnukjkXCX yheESYP/yu9rwGec0Fw6nz+v6G1BxDzajbroJ0pB6Yed8K15jnegEbesX6P/AFFDXw TCqZAnA9Hh/xtKnB/xGB3V64qRXwwlYChqa0H/+Y= From: Kieran Bingham To: libcamera devel Date: Tue, 24 Aug 2021 15:24:49 +0100 Message-Id: <20210824142450.3157833-4-kieran.bingham@ideasonboard.com> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210824142450.3157833-1-kieran.bingham@ideasonboard.com> References: <20210824142450.3157833-1-kieran.bingham@ideasonboard.com> MIME-Version: 1.0 Subject: [libcamera-devel] [SimpleCam PATCH 3/4] simple-cam: Fix the Buffer Allocation guidance X-BeenThere: libcamera-devel@lists.libcamera.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: libcamera-devel-bounces@lists.libcamera.org Sender: "libcamera-devel" The Buffer Allocation notes contains a TODO. Improve the notes regarding the FrameBufferAllocation and remove the todo. Signed-off-by: Kieran Bingham Reviewed-by: Jacopo Mondi Reviewed-by: Laurent Pinchart --- simple-cam.cpp | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/simple-cam.cpp b/simple-cam.cpp index 2e646a5485c9..47c5dc9987bc 100644 --- a/simple-cam.cpp +++ b/simple-cam.cpp @@ -274,10 +274,16 @@ int main() * Buffer Allocation * * Now that a camera has been configured, it knows all about its - * Streams sizes and formats, so we now have to ask it to reserve - * memory for all of them. + * Streams sizes and formats. We need to provide buffers to store + * captured images in. An application might choose to provide buffers + * externally, for instance from a display driver which will render the + * captured images, however libcamera can also provide buffers from a + * configured camera. + * + * To request buffers from libcamera, we use the FrameBufferAllocator, + * and reference the (configured) camera for which we wish to allocate + * buffers for. */ - /* TODO: Update the comment here too */ FrameBufferAllocator *allocator = new FrameBufferAllocator(camera); for (StreamConfiguration &cfg : *config) { From patchwork Tue Aug 24 14:24:50 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Kieran Bingham X-Patchwork-Id: 13462 Return-Path: X-Original-To: parsemail@patchwork.libcamera.org Delivered-To: parsemail@patchwork.libcamera.org Received: from lancelot.ideasonboard.com (lancelot.ideasonboard.com [92.243.16.209]) by patchwork.libcamera.org (Postfix) with ESMTPS id 246D6BD87D for ; Tue, 24 Aug 2021 14:25:00 +0000 (UTC) Received: from lancelot.ideasonboard.com (localhost [IPv6:::1]) by lancelot.ideasonboard.com (Postfix) with ESMTP id 8371868918; Tue, 24 Aug 2021 16:24:59 +0200 (CEST) Authentication-Results: lancelot.ideasonboard.com; dkim=fail reason="signature verification failed" (1024-bit key; unprotected) header.d=ideasonboard.com header.i=@ideasonboard.com header.b="NZQ1HKpV"; dkim-atps=neutral Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [213.167.242.64]) by lancelot.ideasonboard.com (Postfix) with ESMTPS id 4D914688A3 for ; Tue, 24 Aug 2021 16:24:56 +0200 (CEST) Received: from Monstersaurus.local (cpc89244-aztw30-2-0-cust3082.18-1.cable.virginm.net [86.31.172.11]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id C3710BB0; Tue, 24 Aug 2021 16:24:55 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1629815095; bh=uLtkGzOI08JxEDGOv0PwhjLADxuBplDdrHWLOBDq2MI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=NZQ1HKpVgBCLWsrrl+XEBJ7h82jY5X90bFq1hkWGZlwrWlloY+VF84g5MyQsCaT26 QaBuVcDi/HJm6XdR2peXibZVRACY/hPl9ECYCmkeAoRt0XleDRMBGUDRMzeqYAd5dE JmttfY3UPRfXFRD6C2m1yySGVVsqGp79X8djEjb0= From: Kieran Bingham To: libcamera devel Date: Tue, 24 Aug 2021 15:24:50 +0100 Message-Id: <20210824142450.3157833-5-kieran.bingham@ideasonboard.com> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210824142450.3157833-1-kieran.bingham@ideasonboard.com> References: <20210824142450.3157833-1-kieran.bingham@ideasonboard.com> MIME-Version: 1.0 Subject: [libcamera-devel] [SimpleCam PATCH 4/4] simple-cam: Correct the capitalisation of 'libcamera' X-BeenThere: libcamera-devel@lists.libcamera.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: libcamera-devel-bounces@lists.libcamera.org Sender: "libcamera-devel" Even when used at the beginning of a sentence, the 'libcamera' name always starts with a lower case 'l'. Fix the incorrect usages of the name. Signed-off-by: Kieran Bingham Reviewed-by: Jacopo Mondi Reviewed-by: Laurent Pinchart --- simple-cam.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/simple-cam.cpp b/simple-cam.cpp index 47c5dc9987bc..7ba423df9089 100644 --- a/simple-cam.cpp +++ b/simple-cam.cpp @@ -301,7 +301,7 @@ int main() * -------------------------------------------------------------------- * Frame Capture * - * Libcamera frames capture model is based on the 'Request' concept. + * libcamera frames capture model is based on the 'Request' concept. * For each frame a Request has to be queued to the Camera. * * A Request refers to (at least one) Stream for which a Buffer that @@ -348,7 +348,7 @@ int main() * -------------------------------------------------------------------- * Signal&Slots * - * Libcamera uses a Signal&Slot based system to connect events to + * libcamera uses a Signal&Slot based system to connect events to * callback operations meant to handle them, inspired by the QT graphic * toolkit. * @@ -398,12 +398,13 @@ int main() int ret = loop.exec(); std::cout << "Capture ran for " << TIMEOUT_SEC << " seconds and " << "stopped with exit status: " << ret << std::endl; + /* * -------------------------------------------------------------------- * Clean Up * * Stop the Camera, release resources and stop the CameraManager. - * Libcamera has now released all resources it owned. + * libcamera has now released all resources it owned. */ camera->stop(); allocator->free(stream);